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本 书 是 (SQL Server 2016 数据 库 应 用 与 开发 )( 姜 桂 洪 主编 ,2018 年 由 清华 大 学 出 版 社 
出 版 ) 的 配套 辅导 教材 。 书 中 采用 目前 实际 生产 和 教学 领域 内 应 用 广泛 的 SQL Server 数据 
库 管 理 系统 ,利用 内 容 丰 富 的 习题 及 答案 .涵盖 SQL Server 2016 所 有 重要 组 件 的 实验 基本 
操作 ,典型 的 模拟 试题 等 形式 ,从 多 视角 为 初学 者 提供 了 在 Windows 系列 平台 上 学 习 和 开 
发 大 型 数据 库 的 服务 空间 。 

本 书 从 基本 操作 着 手 , 从 教学 实际 需求 出 发 ,结合 初学 者 的 认 知 规律 ,由 浅 入 深 、 精 心 选 
择 SQL Server 2016 数据 库 管理 与 开发 过 程 中 的 知识 点 ,以 数据 库 及 相关 数据 库 对 象 为 基 
础 ,以 备份 .还 原 .复制 和 监视 等 数据 库 系统 管理 组 件 为 目标 ,以 形式 多 样 \ 内 容 丰 富 的 习题 
和 参考 答案 对 基本 操作 进行 示范 ,与 主教 材 及 微 课 视 频 一 起 打造 出 比较 完整 的 立体 化 教材 
的 课程 体系 。 

本 书 在 模块 内 容 安 排 上 体现 循序 渐进 、 重 点 突出 的 特点 。 习 题解 答 部 分 主要 帮助 学 生 
掌握 数据 库 和 Transact-SQL 语句 的 基本 规则 和 基本 操作 。 实 验 部 分 主要 帮助 学 生 进 一 步 
强化 基本 单元 操作 ,培养 学 生 独 立 学 习 的 能 力 。 模 拟 题 可 以 让 学 生 在 掌握 好 所 学 知识 的 基 
础 上 ,进一步 了 解 自己 学 习 本 课程 的 知识 水 平 。 通 过 本 书 提 供 的 指导 材料 ,学 生 可 以 在 自由 
上 机 的 环境 下 ,完成 相关 数据 库 和 Transact-SQL 语句 的 常用 操作 和 管理 。 

全 书 总 共 包 括 如 下 4 部 分 内 容 : 

第 1 部 分 包括 第 1 一 15 章 , 内 容 为 主教 材 的 习题 参考 答案 ,所 有 编程 代码 均 通 过 调试 。 

第 2 部 分 包括 第 16 和 第 17 章 , 内 容 为 SQL Server 2016 系统 的 安装 .配置 和 常用 实践 
环境 操作 的 详细 介绍 。 

第 3 部 分 为 第 18 章 , 介 绍 学 生 上 机 实验 时 需要 注意 的 问题 ,并 根据 教材 内 容 提 供 16 个 
配套 实验 。 实 验 操作 步骤 清晰 、 可 操作 性 强 且 具 代表 性 。 

第 4 部 分 提供 6 套 模拟 试题 及 参考 答案 ,为 读者 学 习 SQL Server 2016 数据 库 提供 自 
我 检查 知识 掌握 水 平 的 契机 , 旨 在 帮助 读者 了 解 和 检验 自己 的 学 习 情 况 。 

本 书 由 姜 桂 洪 任 主编 , 孙 福 振 和 张 冬 梅 编著 ,全 书 由 姜 桂 洪 统 稿 。 在 本 书 的 编写 过 程 
中 , 苏 晶 、 王 德 亮 . 吕 兵 等 教师 也 给 予 了 很 多 帮助 ,在 此 一 并 致谢 。 
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第 1 部 分 
SQL Server 2016 数 据 库 
应 用 与 开发 习题 参考 答案 


学 习 导 读 : 

本 部 分 包括 《SQL Server 2016 数据 库 应 用 与 开发 》 第 1 一 
15 章 所 有 习题 的 参考 答案 ,所 有 代码 均 在 SQL Server 2016 版 
本 的 环境 下 测试 通过 。 

每 章 习题 包括 选择 题 . 思 考题 和 上 机 练习 题 三 种 类 型 ; 

(1) 选择 填空 题 注重 基本 概念 和 基本 操作 的 知识 点 掌握 。 

(2) 思考 题 侧 重 基本 概念 的 理解 。 

(3) 上 机 练习 题 侧 重 的 是 基本 操作 的 练习 。 

建议 在 学 习 过 程 中 ,通过 习题 熟悉 SQL Server 数据 库 的 
基本 概念 和 基本 操作 。 不 要 满足 看 懂 程 序 或 习题 答案 ,要 多 动 
手 做 练习 ,并 且 要 达到 一 定 的 做 题 速度 和 正确 率 。 在 此 基础 上 ， 
借助 于 网 络 或 其 他 工具 ,举一反三 ,解决 一 些 比 教材 习题 更 新 
额 、 算 法 更 复杂 的 问题 。 


第 1 章 数据 库 系统 概述 


1. 选择 题 
(1) 数据 模型 的 三 要 素 不 包括 。 
A. 数据 结构 B. 数据 操作 C. 数据 类 型 D. 完整 性 约束 
(2) 关系 运算 不 包括 。 
A. 连接 B. 投影 C. 选择 D. 查询 
(3) 主 课本 表 1-1 所 示 学 生 信 息 表 中 的 主键 为 。 
A. studentno B. sex C. birthdate D. sname 
(4) 下 面 的 数据 库 产品 中 不 是 关系 数据 库 的 是 
A. Oracle B. SQL Server C. DBTG D. DB2 
(5) E-R 概念 模型 中 ,信息 的 三 种 概念 单元 不 包括 。 
A. 实体 型 B. 实体 值 C. 实体 属性 D. 实体 间 联 系 
答案 : BDACB 
2. 简 答题 


(1) 什么 是 数据 库 数据 库 系 统 和 数据 库 管理 系统 ? 并 且 举 出 日 常生 活 中 一 些 数据 库 
的 实际 范例 。 

【 答 】 数据 库 (Database, DB) 是 长 期 存储 在 计算 机 内 、 有 组 织 、 可 共享 的 大 量 数据 的 
集合 。 
数据 库 管 理 系统 (Database Management System,DBMS) 位 于 用 户 和 操作 系统 之 间 ,是 
一 种 操纵 和 管理 数据 库 的 大 型 软件 ,用 于 建立 、 使 用 和 维护 数据 库 。 它 对 数据 库 进行 统一 的 
管理 和 控制 ,以 保证 数据 库 的 安全 性 和 完整 性 ,是 数据 库 系统 的 核心 。 

数据 库 系统 (Database System,DBS) 通 常 由 硬件 、 软 件 、 数 据 库 和 用 户 组 成 ,管理 的 对 
象 是 数据 。 其 中 软件 主要 包括 操作 系统 、 各 种 宿主 语言 ,实用 程序 以 及 数据 库 管理 系统 。 

日 常生 活 中 , 像 学 生成 绩 管理 ` 网 上 购物 .银行 存 取款 、 购 买 火车 票 等 ,其 软件 的 后 台 
是 由 数据 库 作为 支撑 。 

(2) 说 明 数 据 库 管理 系统 的 基本 系统 架构 拥有 哪 4 大 模块 。 

【 答 】 数据 库 管理 系统 的 基本 系统 包括 如 下 4 大 模块 。 

g@ 存储 管理 (Storage Manager) 。 数 据 库 管理 系统 通常 会 自行 配置 磁盘 空间 ,将 数据 
存 人 存储 装置 的 数据 库 。 

@ 查询 处 理 (Query Processor) 。 负 责 处 理 用 户 下 达 的 查询 语言 命令 语句 ,可 以 再 细 分 
成 多 个 模块 负责 检查 语法 、 优 化 查询 命令 的 处 理 程序 。 

@ 事务 管理 (Transaction Manager) 。 事 务 管理 主要 分 为 : 同名 的 事务 管理 子 系统 , 负 
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责 处 理 数据 库 的 事务 ,保障 数据 库 商业 事务 的 操作 ; 锁定 管理 (Lock Manager) ,也 称 为 并 发 
控制 管理 (Concurrency- Control Manager) 子 系统 ,负责 资源 锁定 。 

@ 恢复 管理 (Recovery Manager) 。 恢 复 管理 主要 是 日 志 管 理 (Log Manager) 子 系统 ， 
负责 记录 数据 库 的 所 有 操作 ,包含 事务 日 志 , 以 便 同 名 的 恢复 管理 子 系统 能 够 执行 恢复 处 
理 , 恢 复数 据 库 系统 存储 的 数据 到 指定 的 时 间 点 。 

(3) 简单 说 明 数 据 库 系统 的 组 件 。 

【 答 】 数据 库 系统 主要 包括 如 下 组 件 。 

@ 用 户 (Users)。 用 户 执行 DDL 请 言 定义 数据 库 架构 ,使 用 DML 语言 新 增 、 删 除 、 更 
新 和 查询 数据 库 的 数据 ,通过 操作 系统 访问 数据 库 的 数据 。 

@ 数据 (Data) 。 数 据 库 系统 中 的 数据 种 类 包括 永久 性 数据 (Persistent Data) 索引 数 
据 (Indexes) 数据 字典 (Data Dictionary) 和 事务 日 志 (Transaction Log) 等 。 

@ 软件 (Software) 。 在 数据 库 环境 中 使 用 的 软件 ,包括 数据 库 管 理 系统 CDBMS) 、 应 用 
程序 (Application Program) 和 开发 工具 (Development Tools) 。 

@ 硬件 (Hardware)。 安 装 数据 库 相 关 软 件 的 硬件 设备 ,包含 主机 (CPU、 内 存 和 网 卡 
等 ) 磁盘 驱动 器 .磁盘 阵列 .光盘 驱动 器 、 磁 带 机 和 备份 装置 。 

(4) 举例 说 明 三 种 关系 运算 的 特点 。 

【 答 】 Q@ 选择 关系 用 于 查找 符合 条 件 的 行 , 从 而 形成 新 关系 。 新 关系 和 原来 关系 结构 
一 致 ,记录 行 变 少 。 例 如 ,在 学 生 表 中 查询 年 龄 18 岁 以 上 的 学 生 记录 。 

@ 投影 关系 是 从 一 个 表 中 找 出 若干 字段 形成 一 个 新 关系 的 操作 ,新 关系 与 原来 关系 的 
记录 行 应 该 一 样 多 ,但 其 数据 列 变 少 。 例 如 ,在 学 生 表 中 输出 学 生 的 学 号 、 姓 名 和 出 生日 期 。 

@ 连接 关系 是 从 两 个 表 中 选择 满足 条 件 的 记录 , 且 新 关系 中 包含 原来 多 个 关系 的 列 ， 
新 关系 结构 中 的 列 类 型 由 原来 关系 中 的 列 映射 而 来 。 例 如 ,查询 学 生 的 学 号 、 姓 名 和 期 末 
成 绩 。 
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1. 选择 题 
(1) SQL Server 2016 系统 的 示例 数据 库 可 以 有 

下 -下 外 B. 3 个 GC 多 个 D. 无 数 个 
(2) 下 面 系统 数据 库 中 ， 数据 库 不 允许 进行 备份 操作 。 

A. master B. msdb C. model D. tempdb 


(3) 下 列 关 于 SQL Server 2016 实例 的 说 法 中 ,正确 的 是 
A. 不 同 版 本 的 默认 实例 数 可 能 不 一 样 多 
B. 不 同 版 本 的 命名 实例 数 一 定 一 样 多 
C. 不 同 版 本 的 默认 实例 只 有 一 个 ,命名 实例 数 不 一 样 多 
D. 不 同 版 本 的 命名 实例 只 有 一 个 ,默认 实例 数 不 一 样 多 


(4) 下 列 数据 库 是 SQL Server 2016 在 创建 数据 库 时 可 以 使 用 的 模板 。 
A. master B. msdb C. model D. resourc 
(5) 默认 情况 下 ,SQL Server 2016 的 系统 数据 库 有 个 。 
A.1 B; 泪 C4 D. 6 
答案 : CDCCB 
2. 思考 题 


(1) 什么 是 SQL Server 2016 实例 ?其 主要 功能 有 哪些 ? 

【 答 】 SQL Server 2016 的 实例 (Instance) 实 际 上 就 是 虚拟 的 SQL Server 服务 器 。 每 
个 实例 都 包括 一 组 私有 的 程序 和 数据 文件 ,同时 也 可 以 和 其 他 实例 共用 一 组 共享 程序 或 
文件 。 

在 数据 库 实例 中 ,可 以 创建 数据 库 及 其 对 象 ,实现 安全 性 ,复制 服务 器 对 象 ,管理 SQL 
Server 代理 等 。 数 据 库 引擎 是 服务 器 的 核心 部 件 ,SQL Server Management Studio 是 SQL 
Server 2016 最 重要 的 管理 工具 ,用 于 访问 .配置 和 管理 SQL Server 2016 的 组 件 。 

(2) 简 述 SQL Server 2016 的 服务 器 与 客户 端的 关系 。 

【 答 】 在 使 用 SQL Server 2016 软件 过 程 中 ,客户 端 (Client) 通 常 是 指 一 些 适合 家 庭 、 
实验 室 、 办 公 环 境 下 使 用 的 安装 了 一 些 享用 网 络 服务 的 PC, 这 些 PC 上 网 的 目的 是 享受 各 
种 网 络 服务 。 

服务 器 (Server) 是 指 具 有 适应 大 容量 的 数据 存储 和 频繁 的 客户 端的 访问 操作 的 计算 
机 ,这 类 计算 机 一 般配 置 大 容量 硬盘 、24 小 时 不 间断 的 UPS 电源 .具备 可 热 搬 拔 功能 、 安 装 
服务 器 操作 系统 下 的 IIS 软件 等 ,能够 在 计算 机 网 络 中 提供 各 种 网 络 服务 。 

客户 端 通过 网 络 将 要 求 传递 给 服务 器 ,服务 器 按照 客户 端的 要 求 返回 结果 。 
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(3) SQL Server 2016 Management Studio 集成 环境 有 哪些 主要 功能 ? 

【 答 】 在 SQL Server 2016 的 系统 中 ,SQL Server Management Studio 是 最 重要 的 管 
理工 具 ,也 是 SQL Server 2016 的 可 视 化 集成 环境 ,用 于 访问 .配置 和 管理 SQL Server 2016 
的 组 件 。 

通过 SQL Server Management Studio 图 形 界 面 ,数据库 管理 员 可 以 调用 其 他 管理 工具 
来 完成 日 常 管理 操作 。 并 与 Visual Studio 开发 平台 集成 在 一 起 ,形成 了 一 个 集 数据 库 的 管 
理 与 应 用 开发 风格 一 致 的 界面 环境 ,用 于 完成 SQL Server 2016 的 最 基本 操作 。 

(4) 简 述 SQL Server 2016 的 主要 服务 项 目的 功能 。 

【 答 】 SQL Server 2016 的 主要 服务 项 目的 功能 简 述 如 下 。 

@ 集成 服务 (Integration Services,IS) 。 集 成 服务 几乎 可 以 在 任何 类 型 的 数据 源 之 间 
移动 数据 , 它 是 SQL Server 的 数据 提取 一 转换 一 加 载 (ETL) 工 具 。 

@ 分 析 服 务 (Analysis Services) 。 分 析 服 务 的 主要 作用 是 通过 服务 器 和 客户 端 技术 的 
组 合 提供 联机 分 析 处 理 (Online Analytical Processing,OLAP) 和 数据 挖掘 功能 。 

@ 报表 服务 (Reporting Services, RS)。SQL Server 2005 报表 服务 的 主要 功能 : 最 新 
而 便捷 的 Dundas 控件 .最 新 的 Tablix 控件 , 重 写 的 内 存 管 理 系统 ,以 及 直接 通过 HTTP. sys 
访问 等 。 

@ SQL Server 代理 (Agent) 。SQL Server 代理 是 一 个 可 选 进程 ,运行 时 执行 SQL 作 
业 并 处 理 其 他 自动 任务 。 系 统 启动 时 可 以 配置 为 自动 运行 ,或 可 以 从 SQL Server 配置 管理 
器 或 Management Studio 的 Object Explorer( 对 象 资源 管理 器 ) 中 启动 。 

@ 复制 服务 。 数 据 库 复制 可 用 于 数据 分 发 或 移动 数据 处 理应 用 程序 、 系 统 高 可 用 性 、 
企业 报表 解决 方案 的 后 备 数 据 可 伸缩 并 发 性 、 与 异 构 系统 (包括 已 有 的 Oracle 数据 库 ) 的 集 

@ 全 文 搜索 。SQL Server 包含 对 数据 表 中 基于 纯 字符 的 数据 具有 进行 全 文 搜索 的 功 
能 。 全 文 搜索 可 以 包括 字 词 和 短语 ,或 者 一 个 字 词 或 短语 的 多 种 形式 。 

@ 主 数据 服务 。 主 数据 服务 是 建立 在 以 SQL Server 数据 库 技术 作为 后 端 处 理 之 上 ， 
使 用 Windows 通信 基础 技术 ,提供 了 面向 服务 架构 终端 的 方案 。 这 是 一 个 包括 复制 服务 、 
服务 代理 .通知 服务 和 全 文 检索 等 功能 组 件 共同 构成 完整 的 服务 架构 。 

@@ 服务 中 介 。 该 功能 可 以 帮助 开发 人 员 生 成 可 伸缩 的 ,安全 的 数据 库 应 用 程序 ,提供 
一 个 基于 消息 的 通信 平台 ,使 独立 的 应 用 程序 组 件 可 以 作为 一 个 整体 来 运行 。Service 
Broker 提供 了 生成 分 布 式 应 用 程序 所 需 的 大 部 分 基础 结构 ,从 而 减少 了 应 用 程序 的 开发 
时 间 。 

开发 工具 。SQL Server 为 数据 库 引擎 ,数据 抽取 、 转 换 和 装载 .数据 挖掘 .OLAP 和 
报表 提供 了 和 Microsoft Visual Studio 相 集成 的 开发 工具 ,以 实现 端 到 端的 应 用 程序 开发 
能 力 。SQL Server 中 每 个 主要 的 子 系统 都 有 自己 的 对 象 模型 和 应 用 程序 接口 (API) ,能 够 
将 数据 系统 扩展 到 任何 独特 的 商业 环境 中 。 

(5) 简 述 系统 数据 库 master、msdb、model 及 tempdb 的 功能 。 

【 答 】 SQL Server 2016 的 系统 数据 库 主要 功能 介绍 如 下 。 

@ master 数据 库 是 SQL Server 系统 最 重要 的 数据 库 , 它 记录 了 SQL Server 系统 的 所 
有 系统 信息 。master 数据 库 还 记录 了 所 有 其 他 数据 库 的 存在 .数据库 文 件 的 位 置 以 及 SQL 


Server 的 初始 化 信息 。 

@ model 数据 库 用 于 在 SQL Server 实例 上 创建 所 有 数据 库 的 模板 。 

@ msdb 数据 库 是 代理 服务 数据 库 ,为 其 报警 任务 调度 和 记录 操作 员 的 操作 提供 存储 
空间 。 

@ tempdb 数据 库 是 一 个 为 所 有 的 临时 表 、 临 时 存储 过 程 及 其 他 临时 操作 提供 存储 空 
间 的 临时 数据 库 。SQL Server 每 次 启动 时 ,tempdb 数据 库 被 重新 建立 。 当 用 户 与 SQL 
Server 断 开 连接 时 ,其 临时 表 和 存储 过 程 自动 被 删除 。 

tempdb 数据 库 由 整个 系统 的 所 有 数据 库 使 用 ,不 管用 户 使 用 哪个 数据 库 , 所 建立 的 所 
有 临时 表 和 存储 过 程 都 存储 在 tempdb 上 。 

3. 上 机 练习 题 

(1) 练习 启动 .暂停 和 停止 SQL Server 2016 服务 管理 器 的 基本 步骤 。 

【 答 】 启动 .暂停 和 停止 SQL Server 2016 服务 管理 器 的 方式 有 三 种 : 使 用 SQL 
Server 配置 管理 器 .使 用 SQL Server Management Studio 配置 服务 器 、 使 用 SQL Server 服 
务 。 下 面 重点 介绍 利用 SQL Server Management Studio 进行 启动 .暂停 和 停止 SQL Server 
2016 服务 管理 器 的 基本 步骤 。 具 体 步骤 如 下 : 

@ 启动 SQL Server Management Studio ,连接 SQL Server 服务 器 。 

@ 选择 菜单 栏 中 的 “视图 ”一 "已 注册 服务 器 ”命令 ,在 弹出 的 “已 注册 服务 器 ?窗口 中 右 
击 一 个 SQL Server 2016 服务 管理 器 。 

@@ 在 弹出 的 快捷 菜单 中 分 别 选择 “启动 交 停 止 ”暂停 ”重新 启动 ”命令 , 即 可 实现 上 述 
操作 。 

(2) 练习 注册 服务 器 的 主要 步骤 。 

【 答 】 在 安装 SQL Server Management Studio 之 后 首次 启动 它 时 ,系统 将 自动 注册 
SQL Server 的 本 地 实例 ,用 户 也 可 以 使 用 SQL Server Management Studio 自己 注册 服务 
器 。 用 户 自己 注册 服务 器 的 主要 参考 步骤 如 下 : 

@ 在 SQL Server Management Studio 界面 的 工具 栏 中 选择 “已 注册 的 服务 器 ”命令 按 
钮 ,在 窗 体 左 侧 出 现 “ 已 注册 的 服务 器 "窗口 , 右 击 “数据 库 引 擎 ”。 

@ 在 弹出 的 快捷 菜单 中 选择 “新 建 ”>“ 服 务 器 注册 ”命令 。 

@ 在 弹出 的 “新 建 服务 器 注册 ”对 话 框 中 指定 下 列 选项 : 服务 器 的 类 型 、 服 务 器 名 称 、 
登录 到 服务 器 的 身份 验证 方式 、 用 户 名 和 密码 等 描述 信息 。 

@ 为 正在 注册 的 服务 器 选择 连接 属性 。 即 在 “连接 属性 ”选项 卡 中 可 以 指定 下 列 连 接 
选项 : 默认 情况 下 连接 的 数据 库 、 使 用 的 网 络 协议 .默认 网 络 数据 包 大 小 ,以 及 连接 超时 、 执 
行 超时 、 加 密 连 接 信息 等 。 

@ 单 击 “ 保 存 ” 按 钮 。 

(3) 练习 模板 资源 管理 器 的 使 用 方法 和 脚本 的 使 用 方法 。 

【 答 】 模板 资源 管理 器 主要 用 于 查看 和 调用 模板 等 操作 。 模 板 的 真正 作用 在 于 它 能 为 
必须 频繁 创建 的 复杂 脚本 创建 自 定义 模板 。 这 些 模 板 是 包含 必要 表达 式 的 基本 结构 的 文 
件 , 以 便 在 数据 库 中 新 建 对 象 。 

通过 选择 菜单 栏 中 的 “视图 ”一 “模板 资源 管理 器 "命令 ,打开 “模板 资源 管理 器 ” 
窗口 。 
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@ 若 要 查看 不 同类 型 服务 的 语法 模板 ,可 以 通过 “模板 资源 管理 器 ”窗口 最 上 方 的 工具 
行 切换 三 种 不 同 的 语法 模板 : SQL Server 模板 、Analysis Services 模板 和 SQL Mobile 模 
板 , 如 图 2-1 所 示 。 若 双击 模板 中 的 选项 ,可 以 在 查询 设计 器 中 观察 到 该 项 模板 的 代码 ,如 
给 表 添 加 列 。 


ms 
加 入 Stored Procedure 四 
日 岛 synonm 
日 国 Tsble 
对 Md Celomn 
国 Md constraint 
国 Aaa Filestrean colmn 
国 Aaa Key 
国 create Table with Filestream Colunn 
国 Create Table 
国 Drop colmn 
男 mrop Constraint 
国 prop Fey 
国 Drop Table 
田 国 Trigger 
田 国 Vser 


| 
田 Vser-defined Data Type 
田 a Vser-defined Table Type 一 


2-1 利用 模板 资源 管理 器 修改 表 


@ 如 果 不 熟 悉 如何 通 过 相关 语言 完成 某 项 任务 ,可 以 查找 预先 提供 的 模板 ,通过 修改 
部 分 内 容 来 完成 任务 。 

@ 利用 模板 创建 数据 库 ,数据 表 、 视 图 索引、 存储 过 程 、. 触 发 器 .统计 数据 和 函数 等 数 
据 库 对 象 。 还 有 一 些 模板 可 创建 连接 服务 器 、 登 录 、 角 色 、 用 户 等 。 
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1. 选择 题 
(1) 创建 SQL Server 2016 的 用 户 数据 库 时 ,最 多 不 能 超过 从 

A. 100 B. 40 000 C20 D. 30 000 
(2) SQL Server 2016 数据 库 文件 有 三 类 ,其 中 主 数据 文件 的 扩展 名 为 

A. ndf B. ldf C. mdf D. idf 
(3) SQL Server 2016 的 每 个 数据 文件 的 基本 存储 单位 的 大 小 是 

A. 8KB B. 8060B C. 64KB D. 512B 
(4) 从 逻辑 角度 看 ,数据 库 对 象 不 包括 : 

A. 表 B. 数据 库 C. 视图 D. 日 志文 件 


(5) 以 下 关于 数据 存储 的 描述 ,错误 的 是 
A. 所 有 数据 库 都 有 一 个 主要 数据 库 文件 (. mdf) 
B. 创建 数据 库 时 会 将 model 数据 库 复 制 到 新 数据 库 
C. 同一 行 的 数据 可 以 随意 存储 在 不 同 的 页 上 
D. 一 个 数据 库 中 每 兆 字 节 的 空间 能 存储 128 页 
说 明 : 同一 行 的 数据 一 般 存 储 在 一 个 页 面 上 ,特殊 情况 下 可 以 存储 在 不 同 页 面 上 ,但 不 
是 随意 的 。 
答案 : BCADC 
2. 思考 题 
(1) 简 述 SQL Server 2016 中 文件 组 的 作用 和 分 类 。 
【 答 】 SQL Server 2016 中 文件 组 的 作用 主要 包括 如 下 几 个 方面 。 
Q@ 对 于 大 型 数据 库 , 如 果 硬 件 设置 上 需要 多 个 磁盘 驱动 器 ,就 可 以 把 特定 的 对 象 或 文 
件 分 配 到 不 同 的 磁盘 上 ,将 数据 库 文 件 组 织 成 用 户 文件 组 。 
@ 文件 组 可 以 帮助 数据 库 管理 人 员 执 行 相应 的 数据 布局 ,以 及 某 些 管理 任务 ,如 将 数 
据 文件 集合 起 来 ,以 便于 管理 .数据 分 配 和 放置 。 
@ 利用 文件 组 可 以 在 特定 的 文件 中 定位 特定 的 对 象 , 从 而 将 频繁 查询 和 频繁 修改 的 文 
件 分 离 出 来 ,以 提高 磁盘 驱动 器 的 效率 ,减少 磁盘 驱动 器 的 争 用 。 
@ 为 便于 分 配 和 管理 ,可 以 将 数据 库 对 象 和 文件 一 起 分 成 文件 组 。 文 件 组 的 两 种 类 型 
如 下 。 
。 主 文件 组 。 包 含 主 数据 文件 和 任何 没有 明确 分 配给 其 他 文件 组 的 其 他 文件 。 系 统 
表 的 所 有 页 均 分 配 在 主 文件 组 中 。 
。 用 户 定义 文件 组 。 通 过 在 CREATE DATABASE 或 ALTER DATABASE 语句 中 
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使 用 FILEGROUP 关键 字 指 定 的 任何 文件 组 。 

(2) 简 述 如 何在 SQL Server Management Studio 中 修改 数据 库 的 属性 。 

【 答 】 利用 SQL Server Management Studio 修改 数据 库 的 参考 步骤 如 下 。 

@ 在 对 象 资源 管理 器 中 ,用 户 可 以 右 击 所 选择 的 数据 库 ,在 弹出 的 快捷 菜单 中 选择 “ 属 
性 ”命令 打开 “数据 库 属性 ”窗口 。 在 “常规 ”选项 卡 中 显示 的 是 数据 库 的 基本 信息 ,这 些 信息 
不 能 修改 。 

@ 选择 “文件 ?选项 卡 ,可 以 修改 数据 库 的 逻辑 名 称 、 初 始 大 小 .自动 增长 等 属性 ,也 可 
以 根据 需要 添加 数据 文件 和 日 志文 件 , 还 可 以 更 改 数据 库 的 所 有 者 。 

单 击 * 添 加 ?按钮 可 以 添加 数据 文件 .日 志文 件 ,并 分 别 设置 其 增长 方式 和 大 小 。 修 改 内 
容 后 , 单 击 “ 确 定 ” 按 钮 即 可 。 

@ 在 “文件 组 ?选项 卡 中 可 以 修改 现 有 的 文件 组 ,也 可 以 指定 数据 库 的 默认 文件 组 、 添 
加 新 文件 组 。 

@ 在 “选项 ”选项 卡 中 修改 数据 库 的 排序 规则 。 

@“ 数 据 库 属性 ”窗口 还 包含 权限 、 镜 像 、 事 务 日 志 传 送 等 各 种 属性 ,只 要 需要 ,就 可 以 
选择 相应 的 选项 卡 来 修改 。 

(3) 简 述 如 何在 SQL Server Management Studio 中 分 离 和 附加 数据 库 。 

【 答 】 在 SQL Server 2016 中 ,所 有 用 户 数据 库 都 可 以 从 服务 器 的 管理 中 进行 分 离 ,以 
脱离 服务 器 的 管理 ,同时 保持 数据 文件 与 日 志文 件 的 完整 性 和 一 致 性 。 而 分 离 出 来 的 数据 
库 可 以 附加 到 其 他 SQL Server 服务 器 上 ,构成 完整 的 数据 库 。 

Oz 分 离 用 户 数据 库 。 在 SQL Server Management Studio 中 右 击 选择 的 数据 库 , 从 弹出 
的 快捷 菜单 中 选择 “任务 ”分 离 ” 命 令 。 

在 弹出 的 对 话 框 中 设置 是 否 删除 连接 、 是 否 更 新 统计 信息 、 是 否 保留 全 文 目录 以 及 是 否 
就 绪 等 分 离 参 数 , 单 击 “ 确 定 ” 按 钮 即 可 完成 操作 。 

@ 附加 数据 库 。 在 SQL Server Management Studio 中 右 击 “对 象 资 源 管理 回 ” 中 的 “ 数 
据 库 ”, 从 弹出 的 快捷 菜单 中 选择 “附加 ”命令 。 

在 弹出 的 “附加 数据 库 ” 对 话 框 中 单 击 “ 添 加 ”按钮 ,目的 是 将 要 附加 数据 库 的 主 数 据 文 
件 添加 到 实例 。 在 弹出 的 “数据 库 定位 文件 "界面 中 选择 要 添加 的 数据 库 的 主 数据 文件 , 单 
击 “ 确 定 ” 按 钮 返回 “附加 数据 库 ” 对 话 框 , 青 单 击 “ 确 定 ” 按 钮 ,该 数据 库 就 附加 到 当前 的 实例 
中 人 

(4) 简 述 收缩 数据 库 的 作用 及 在 SQL Server Management Studio 中 收缩 数据 库 的 
步骤 。 

【 答 】 当 系 统 为 数据 库 分 配 的 磁盘 空间 过 大 时 可 以 收缩 数据 库 , 以 节省 存储 空间 。 数 
据 文 件 和 事务 日 志文 件 都 可 以 进行 收缩 。 数 据 库 也 可 设置 为 按 给 定 的 时 间 间 隔 自动 收缩 。 
该 活动 在 后 台 进 行 ,不 影响 数据 库 内 的 用 户 活动 。 

在 SQL Server Management Studio 中 收缩 数据 库 的 参考 步骤 如 下 。 

@ 在 SQL Server Management Studio 中 右 击 选择 的 数据 库 ,从 弹出 的 快捷 菜单 中 选择 
“任务 ”一 收缩 ”一 数据库 ?命令 。 

@ 在 弹出 的 对 话 框 中 设置 数据 库 的 当前 分 配 空 间 : 单 击 “确定 ?按钮 即 可 完成 操作 。 系 
统 将 根据 数据 库 的 具体 情况 对 数据 库 进 行 收缩 。 


@ 若 单 击 “脚本 ”按钮 ,系统 还 能 够 将 收缩 操作 的 脚本 显示 到 查询 设计 器 界面 中 ,例如 : 


DBCC SHRINKDATABASE(N 'test01', 45 ) 
GO 


@ 若 在 SQL Server Management Studio 中 右 击 相应 的 数据 库 , 从 弹出 的 快捷 菜单 中 选 
择 “ 任 务 ” 盖 收缩 ”一 文件 ?命令 ,在 弹出 的 对 话 框 中 设置 收缩 数据 库 文件 的 参数 , 单 击 “ 确 
定 ” 按 钮 也 可 完成 收缩 数据 库 操作 。 

(5) 说 明 数 据 库 中 事务 日 志文 件 与 数据 文件 分 别 存 放 的 优点 。 

【 答 】 SQL Server 2016 数据 库 中 数据 文件 包含 数据 和 对 象 ,日 志文 件 包 含 恢复 数据 
库 中 所 有 事务 所 需 的 信息 。 

默认 情况 下 ,数据 和 事务 日 志 被 放 在 同一 个 驱动 器 上 的 同一 个 路 径 下 。 这 是 为 处 理 单 
磁盘 系统 而 采用 的 方法 。 但 是 ,在 生产 环境 中 建议 将 数据 和 日 志文 件 放 在 不 同 的 磁盘 上 。 
一 旦 存储 数据 文件 或 日 志文 件 的 磁盘 发 生 损 坏 ,可 以 采取 相应 的 措施 保护 数据 。 

3. 上 机 练习 题 

(1) 使 用 SQL Server Management Studio 创建 名 为 test03 的 数据 库 , 并 设置 数据 库 主 
文件 名 为 test03_data, 大 小 为 10MB; 日 志文 件 名 为 test03_log, 大 小 为 2MB。 

【 答 】 在 SQL Server Management Studio 中 创建 数据 库 test03 的 步骤 如 下 。 

@ 启动 SQL Server Management Studio ,在 “对 象 资源 管理 器 ”中 右 击 “ 数 据 库 ? 选 项 ， 
在 弹出 的 快捷 菜单 中 选择 “新 建 数据 库 ? 命 令 , 打 开 * 新 建 数 据 库 ?窗口 。 

@ 在 “常规 ”选项 卡 中 的 “数据 库 名 称 ”文本 框 中 输入 数据 库 名 称 test03。 

@ 在 “文件 ”选项 卡 中 修改 数据 库 主 文件 名 为 test03_data, 大 小 为 10MB; 日 志文 件 名 
为 test03_log, 大 小 为 2MB。 

@ 在 “选项 ”选项 卡 中 设置 “排序 规则 ”恢复 模式 ”等 选项 。 

@ 其 他 选项 通过 接受 默认 值 来 创建 数据 库 。 所 有 参数 设置 完毕 后 , 单 击 “确定 ”按钮 ， 
新 的 数据 库 就 创建 成 功 了 。 展 开 * 对 象 资源 管理 器 "中 的 数据 库 项 ,就 可 以 观察 到 test03 数 
据 库 已 经 创建 成 功 。 

(2) 创建 一 个 名 称 为 studentl 的 数据 库 , 该 数据 库 的 主 文件 逻辑 名 称 为 studentl_ 
data, 物 理 文件 名 为 studentl. mdf ,初始 大 小 为 6MB, 最 大 尺寸 为 无 限 大 ,增长 速度 为 15%; 
数据 库 的 日 志文 件 逻 辑 名 称 为 studentl_log ,物理 文件 名 为 student1. 1df ,初始 大 小 为 3MB， 
最 大 尺寸 为 30MB, 增 长 速度 为 2MB; 要 求 数据 库 文 件 和 日 志文 件 的 物理 文件 都 存放 在 D:\ 
DATA 文件 夹 下 。 

【 答 】 创建 数据 库 studentl 的 参考 步骤 如 下 。 

@ 在 DD 盘 创 建 一 个 新 的 文件 夹 ,名 称 是 DATA。 

@ 在 SQL Server Management Studio 中 新 建 一 个 查询 设计 器 的 页 面 。 

@ 输入 以 下 程序 段 并 执行 此 查询 : 


create database studentl 

on primary 

(NAME= studentl1 data, 

FILENAME = 'D:\DATA\student1. mdf ', 


size=6, 
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MAXSIZE = unlimited, 
filegrowth=15%) 

log on 

(NAME = studentl log, 

FILENAME = 'D:\DATA\student1. 1df ', 
size= 3, 

maxsize = 30, 

filegrowth= 2) 


(3) 创建 一 个 指定 多 个 数据 文件 和 日 志文 件 的 数据 库 。 该 数据 库 名 称 为 students, 有 
一 个 5MB 和 一 个 10MB 的 数据 文件 和 两 个 5MB 的 事务 日 志文 件 。 数 据 文件 逻辑 名 称 为 
studentsl 和 students2, 物理 文件 名 为 studentsl. mdf 和 students2. ndf。 主 文件 是 
students1, 由 PRIMARY 指定 ,两 个 数据 文件 的 最 大 容量 均 为 75MB, 增 长 速度 均 为 10%。 
事务 日 志文 件 的 逻辑 名 为 studentslogl 和 studentslog2, 物 理 文件 名 为 studentslogl. 1df 和 
studentslog2. ldf, 最 大 尺寸 均 为 30MB, 文 件 增长 速度 均 为 1MB。 要 求 数据 库 文件 和 日 志 
文件 的 物理 文件 都 存放 在 D:\DATA 文件 夹 下 。 

【 答 】 实现 的 步骤 如 下 。 

OO 在 D 盘 创建 一 个 新 的 文件 夹 ,名 称 是 DATA。 

O@) 在 SQL Server Management Studio 中 新 建 一 个 查询 设计 器 的 页 面 。 

@ 输入 以 下 程序 段 并 执行 此 查询 : 


create database students 

on primary 

(name = students1, 

filename = 'D:\DATA\students1. mdf', 
size=5, 

maxsize = 75, 

filegrowth= 10%), 

(name = students12, 

filename = 'D:\DATA\students2. ndf', 
size=10, 

maxsize = 75, 

filegrowth=10%) 

log on 

(name = studentslogl， 

filename = 'D:\DATA\studentslogl. ldf ', 
size=5, 

maxsize = 30, 

filegrowth= 1), 

(name = studentslog2, 

filename = 'D:\DATA\studentslog2. 1df ', 
size=5, 

maxsize = 30, 

filegrowth=1) 


(4) 删除 已 创建 的 数据 库 students。 


【 答 】 实现 的 步骤 如 下 。 
a@ 在 SQL Server Management Studio 中 新 建 一 个 查询 设计 器 的 页 面 。 


@ 输入 以 下 程序 段 并 执行 此 查询 : 

drop database students 

说 明 : 当 有 别 的 用 户 正 在 使 用 此 数据 库 时 , 则 不 能 进行 删除 操作 。 
(5) 将 已 存在 的 数据 库 studentl 重 命名 为 student_BACK。 

【 答 】 实现 的 步骤 如 下 。 

Oa 在 SQL Server Management Studio 中 新 建 一 个 查询 页 面 。 

@ 输入 以 下 程序 段 并 执行 此 查询 : 


sp_renamedb ' student1 '，' student_BRCK ' 
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1. 选择 题 
(1) SQL Server 2016 的 约束 机 制 中 不 包括 

A. check B. not null C. unique D. rule 
《2) 下列 方法 可 以 实现 引用 完整 性 。 

A. rule B. foreign key C. not null D. default 
(3) 在 Transact-SQL 语法 中 .用 于 插入 和 更 新 数据 的 命令 是 

A. update,insert B. insert,update 

C. delete,update D. create,insert 
(4) 下 列 对 象 不 可 以 在 检查 约束 中 使 用 。 

A. 系统 函数 B. foreign key 

C. not null D. 用 户 定义 的 函数 (UDF) 
(5) 实现 域 完整 性 的 机 制 通常 不 包括 和 

A. 存储 过 程 B. check C. foreign key D. 数据 类 型 
答案 : DBBBA 
2. 思考 题 


(1) 简 述 在 创建 表 结 构 时 常用 数据 类 型 的 主要 作用 。 

【 答 】 在 创建 表 结 构 时 ,常用 的 6 种 标准 数据 类 型 的 主要 作用 是 : 

O@ 精确 数字 数据 类 型 存储 精确 的 整数 值 或 十 进 制 数 。 

@ 近似 数字 数据 类 型 存储 浮 点 数 。 

@ 货币 数据 类 型 存储 精确 到 4 个 小 数位 的 货 T 

@ datetime 数据 类 型 存储 日 期 和 时 间 , date 数据 类 型 存储 日 期 ,time 数据 类 型 存储 
时 间 。 

@ 字符 数据 类 型 存储 文本 值 。 

@ 二 进 制 数据 类 型 存储 二 进 制 流 ,通常 是 文件 。 

(2) 简 述 各 种 约束 对 表 中 数据 的 作用 。 

【 答 】 各 种 约束 对 表 中 数据 的 作用 如 下 。 

@ 检查 约束 限制 一 列 的 允许 值 。 

@ 规则 实现 与 检查 约束 相同 的 功能 ,但 被 实现 为 不 同 于 一 个 特定 表 的 对 象 ,因此 规则 
只 要 创建 一 次 而 可 以 在 很 多 地 方 使 用 。 

@ 默认 约束 在 用 户 没 有 指定 一 个 值 时 在 一 个 列 中 输入 一 个 值 。 

@ 唯一 约束 确保 一 列 或 列 的 组 合 没有 重复 值 。 


@ 主键 确保 一 个 表 中 的 每 一 行 可 以 被 指定 列 或 指定 列 的 组 合 唯一 地 标识 。 一 个 表 只 
能 有 一 个 主键 ,但 可 以 创建 多 个 唯一 约束 。 

@ 外 键 强制 一 个 列 只 能 取 一 个 被 引用 的 表 中 存在 的 值 。 

(3) SQL Server 2016 支持 的 数据 完整 性 有 了 哪 几 类 ? 各 有 什么 作用 ? 

【 答 】 数据 完整 性 可 以 根据 其 作用 的 数据 库 对 象 和 范围 不 同 分 为 4 类 。 具 体 包 括 : 

@ 域 完整 性 。 要 求 列 的 数值 具有 正确 的 类 型 .格式 和 有 效 值 范围 ,并 确定 是 否 允 许 有 
空 值 。 通 常 使 用 有 效 性 检查 强制 域 完整 性 ,也 可 以 通过 限定 列 中 允许 的 数据 类 型 格式 或 有 
效 值 范围 来 强制 数据 完整 性 。 

@ 实体 完整 性 。 要 求 表 中 的 每 一 行 具 有 唯一 的 标识 。 在 数据 库 中 ,如 student 表 中 的 
列 studentno 被 设 为 主键 , 则 会 保证 每 个 学 生 只 有 一 个 学 号 ,而 且 是 唯一 的 。 

@ 引用 完整 性 。 指 两 个 表 的 主键 与 外 键 之 间 定 义 的 数据 完整 性 ,将 确保 主键 和 外 键 的 
关系 。 引 用 完整 性 可 以 保证 两 个 引用 表 间 数据 的 一 致 性 。 

@ 用 户 定义 完整 性 。 用 户 可 以 根据 其 应 用 环境 的 不 同 , 对 数据 库 设置 一 些 特殊 的 约束 
条 件 , 反 映 某 一 具体 应 用 所 涉及 的 数据 必须 满足 的 语句 要 求 。 用 户 定义 完整 性 的 实现 机 制 
有 规则 、 触 发 器 和 存储 过 程 及 创建 数据 表 时 的 所 有 约束 。 

(4) 简 述 在 SQL Server Management Studio 中 创建 含有 主键 的 表 的 步骤 。 

【 答 】 在 SQL Server Management Studio 中 创建 含有 主键 的 表 的 参考 步骤 如 下 。 

QO 在 “对 象 资源 管理 器 "中 展开 要 新 建 表 的 数据 库 。 

@ 右 击 “ 表 ? 节 点 ,在 弹出 的 快捷 菜单 中 选择 新建 表 ”命令 。 

@ 在 弹出 的 “ 表 设 计 器 ”窗口 中 依次 输入 列 名 、 数 据 类 型 及 允许 空 否 等 选项 。 以 此 类 
推 ,设置 其 他 列 的 参数 项 。 

@ 右 击 要 创建 主键 列 , 在 弹出 的 快捷 菜单 中 选择 "设置 主键 ”命令 ,或 者 使 用 "设置 主 
键 ” 按 钮 来 设置 主键 。 

@@ 设置 完毕 后 单 击 “保存 按钮 ,在 弹出 的 对 话 框 中 输入 表 名 后 单 击 “* 确 定 ” 按 钮 即 可 。 

(5) 简 述 在 SQL Server Management Studio 中 修改 表 数 据 的 步骤 。 

【 答 】 在 SQL Server Management Studio 中 修改 表 数 据 的 参考 步骤 如 下 。 

@ 在 “对 象 资源 管理 器 "中 展开 “数据 库 ”>“ 表 ”, 选 择 要 修改 数据 的 表 。 

@ 右 击 该 表 , 在 弹出 的 快捷 菜单 中 选择 “打开 表 ” 命 令 , 然 后 在 窗 体 中 直接 修改 表 的 数 
据 即 可 。 

@ 还 可 以 通过 三 种 Transact-SQL 语句 insert、update 和 delete 在 查询 设计 器 中 进行 数 
据 的 添加 、 更 新 和 删除 操作 。 

3. 上 机 练习 题 

(1) 在 test01 数据 库 中 使 用 Transact-SQL 语句 创建 表 book 和 表 author, 结 构 如 下 : 

book(book_id nchar(6), book_name nchar(30), price numeric(10,2)) 

author(author name nchar(4), book id nchar(6), address nchar(30)) 

设置 book 中 的 book_id 为 主键 ,author 表 中 的 book_id 为 外 键 ,并 设置 两 个 表 的 关系 。 

【 答 】 Q@ 创建 表 book 的 Transact-SQL 语句 : 


USE test01 
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GO 
CREATE TABLE book 
( 
book_id nchar(6) NOT NULL, 
book_name nchar(30) NULL, 
price numeric(10, 2) NULL, 
CONSTRAINT PK_book PRIMARY KEY CLUSTERED 
( book id ASC ) 
)ON [PRIMARY] 


@ 创建 表 author 的 Transact-SQL 语句 : 


CREATE TABLE dbo. author( 
anthor_name nchar(4) NOT NULL, 
book_id nchar(6) NOT NULL, 
address nchar(30) NOT NULL 

) ON [PRIMARY] 


@ 设置 book 中 的 book_id 为 主键 ,author 表 中 的 book_id 为 外 键 : 


ALTER TABLE dbo.author WITH CHECK 

RDD CONSTRAINT FK_ book author FOREIGN KEY(book_id) 

REFERENCES dbo. book (book_id) 

@ 创建 两 个 表 的 外 键 关系 的 步骤 如 下 : 

在 author 表 的 设计 器 界面 右 击 book_id 列 , 在 弹出 的 快捷 菜单 中 选择 “关系 ”命令 , 弹 
出 如 图 4-1 所 示 的 “外 键 关系 ”对 话 框 。 


》 INSERT 和 UPDATE 规范 
强制 外 键 约束 


强制 用 于 复制 


4-1 “外 键 关系 ”对 话 框 


单 击 “ 表 和 列 规范 ”右边 的 … 按 钮 ,弹出 如 图 4-2 所 示 的 “ 表 和 列 ” 对 话 框 ,设置 主键 表 和 
外 键 表 及 book_id 列 , 单 击 “ 确 定 ” 按 钮 。 


在 返回 的 “外 键 关系 ”对 话 框 中 单 击 “ 关 闭 ” 按 钮 ,两 个 表 的 关系 设置 完 


图 4-2 “ 表 和 列 ” 对 话 框 


(2) 在 test01 数据 库 中 利用 Transact-SQL 语句 创建 一 个 图 书 销售 表 booksales, 结 构 
如 下 : booksales (book_id nchar(6)，sellnum int，selldate datetime)。 分 别 利 用 insert、 
delete、update 语句 添加 删除 和 更 新 数据 。 


【 答 】 


Q@ 利用 Transact-SQL 语句 创建 表 booksales 的 代码 : 


USE test01 


GO 


CREATE TABLE booksales( 
book_id nchar(6) NOT NULL, 
sellnum int NOT NULL, 
selldate date NOT NULL 

) ON [PRIMARY] 


@ 利 


用 insert 语句 为 表 booksales 添加 数据 : 


INSERT INTO booksales VALUES ( 'm00011',7,7/8/2016) 
INSERT INTO booksales(book_id, sellnum, selldate) VALUES ( ‘m00017',3,10/8/2016 ) 


Q 利 


用 update 语句 为 表 booksales 更 新 数据 : 


UPDATE booksales SET sellnum = 11 


WHERE 


轩 利 


book_id = 'm00011 


用 delete 语句 删除 表 booksales 的 数据 : 


DELETE FROM booksales 


WHERE 


book_id = "m00011 
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(3) 利用 TransactrSQL 语句 为 表 booksales 中 的 销售 数量 列 sellnum 创建 规则 
sellnum 盖 一 0, 并 绑 定 规则 到 列 sellnum 。 
【 答 】 为 表 booksales 创建 和 绑 定 规则 sellnum_rule 的 代码 如 下 。 


USE test01 
GO 
CREATE RULE sellnum rule 
AS @ sellnum>=0 
EXEC sp_bindrule 'sellnum rule', 'booksales. sellnum ' 


(4) 利用 Transact-SQL 语句 先 删除 表 booksales 中 销售 时 间 在 2015 年 以 前 的 记录 ,再 
删除 全 部 记录 ,然后 删除 该 表 。 

【 答 】 利用 Transact-SQL 语句 删除 表 booksales 数据 的 代码 如 下 。 

DELETE FROM booksales 

WHERE selldate <1/1/2015 

一 删除 所 有 数据 

Truncate Table booksales 

(5) 练习 如 何 利 用 导出 向 导 将 表 book 转换 成 Excel 表 。 

【 答 】 首先 向 book 表 中 输入 若干 行 数据 ,如 图 4-3 所 示 。 然 后 利用 导出 向 导 将 数据 库 
表 book 转换 成 Excel 表 。 


LG37CEYPEQYWCS...stO1 - dbo.book x 


book name price 


4-3 ”book 表 记 录 


具体 参考 步骤 如 下 : 
中 启动 导入 向 导 。 在 资源 管理 器 中 右 击 数据 库 test01, 在 弹出 的 快捷 菜单 中 选择 “ 任 
”>“ 导 出 数据 ”命令 ,如 图 4-4 所 示 。 然 后 弹出 *SQL Server 导入 和 导出 向 导 ” 初 始 界 面 ， 

如 图 4-5 所 示 。 

@ 选择 数据 源 类 型 。 单 击 * 下 一 步 "按钮 ,在 “选择 数据 源 ” 页 面 中 的 “数据 源 " 下 拉 列 表 
框 中 选择 导出 的 数据 源 类 型 SQL Native Client, 如 图 4-6 所 示 。 

@ 选择 目标 。 单 击 “ 下 一 步 "按钮 ,选择 目标 文件 路 径 和 文件 名 ,如 Excel 表 book. xls， 
如 图 4-7 所 示 。 

@ 指定 复制 或 查询 操作 。 单 击 “ 下 一 步 " 按 钮 ,选择 “复制 一 个 或 多 个 表 或 视图 的 数据 " 单 
选 按钮 ,如 图 4-8 所 示 。 单 击 * 下 一 步 ?按钮 ,选择 数据 库 表 book 作为 数据 源 文件 ,如 图 4-9 
所 示 。 


日 图 LG37CEYPE9YWCSG (SQL Server 13.0.200 - LG37CEYPE9YWCSGWdministraton 
日 向 数 撕 库 
国 国 系统 数 掺 库 
日 国 致 扰 亩 快照 
@ ReportServer 
加 国 ReportServerTempDB 
student 


teaching 
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加 SQL Server 导入 和 导出 向 导 - DO x 


欢迎 使 用 SQL Server 导入 和 导出 向 导 


[Re 以 保 在 多 种 党 用 数据 格式 (包括 歼 据 床 、 电 子 表格 和 文本 文件 ) 
间 导 入 和 导出 数据 。 此 问 导 还 可 b 嫂 目标 数据 库 和 用 于 括 入 数据 的 表 ， 


要 将 数据 库 及 其 对 象 从 一 个 | 例 移动 或 复制 到 另 一 个 服务 加 实例 ， 请 取消 此 向 导 ， 
各 全 生生- ti a ee 


厂 不 再 暗示 此 起 始 页 (D)。 


cE | rsm > |] a 5 | wn 
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图 4-5 “SQL Server 导入 和 导出 向 导 ” 初 始 界 面 
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加 sQL server 导入 和 导出 向 导 一 OO 其 
先 丘 其 扫 疙 ,sgngmes 。 1 
| 
1 
数据 源 (D): [erosott oz yp Provider for SQL Server | 
服务 器 名 称 (S): Escsa] 本 
身份 验证 
从 使 用 Windows 身份 验证 (W) 
个 使 用 SQL Server 身份 验证 (9) 
用 户 名 (由 |EEEseseseeeeeeeeeeeeesseeseees| 
密码 (?) 「 
雪 据 诛 (7); MM 


才 助 (WD < 上- 步 (3) Rr) 7 取消 
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| - oO x 


选择 括 sspinlgaietat 站 


目标 (9): 区 assets 了 
FExeel 连接 设置 
了 xeel 文件 路 径 (X) 
Psar aoi6VWbook xls 
了 xeel 版 本 (V); 
Perosoft Excel 97-2003 | 
民 首 行 包 含 列 名 称 (P) 


《 上 一 步 (B) 下 一 步 (8) > 完成 (r) >>| 取消 


图 4-7 选择 目标 


BB SQL server 导入 和 导出 向 导 - oO x 


指定 表 复 
指证 得 起 久 记 as 个 表 和 视图 ， 还 是 从 教 据 源 复制 查 词 结果。 


6 复制 一 个 或 条 个 去 或 视图 的 数据 (C) 
此 选项 用 于 夏 制 源 雪 据 库 中 现 有 表 或 视图 的 全 部 数据 * 


个 编写 查 鹿 以 指定 要 传输 的 数据 (W) 
此 选项 用 于 编写 SQL 查询， 以 便 对 复制 操作 的 源 孝 据 进行 操纵 或 限制 。 


帮助 (中 < 上 -上 om) | Ts >»] 了 消 


图 4-8 指定 复制 或 查询 


和 和 
一 个 或 多 个 要 槛 制 的 表 和 视图 。 


表 和 视图 (7) 

也 | 源 : LG37CEYPE9YWCSG 目标 : D;\SQL 2016\book zs 
F 加 [ab [oather] 

FD Cabe] Geo 四 “book 

IF 加 [dbo]. [bookssles] 

IF 回 [ao [sch_ship] 

IF [abo]. [student!] 


编辑 映射 (E) 


才 上 洪 
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@ 编辑 和 预览 文件 。 单 击 映 射 列 下 的 “编辑 映射 "按钮 ,可 以 查看 数据 库 表 book 的 结 
果 , 如 图 4-10 所 示 。 如 果 单 击 “ 编 辑 SQL” 按 钮 ,还 可 以 使 用 “Create Table SQL 语句 ”对 话 
框 中 的 默认 语句 ,或 按 要 求 进行 修改 。 如 果 要 修改 此 语句 ,还 必须 对 表 映 射 进行 相关 更 改 。 
单 击 “ 确 定 ” 按 钮 返回 图 4-9 所 示 界 面 。 


= 口 x | 


源 : [dbo]. [book] 
目标 “book” 


eat 
个 障 除 目标 过 中 的 行 (W) 厂 星 除 并 重新 创建 目标 表 (D) 
个 向 目标 才 中 词 加 行 (P) 

映射 O0 


源 列 book_id nchar (6) NWOT WULL 


中 | ma | 


图 4-10 列 映射 
若 单 击 “ 预 览 ” 按 钮 ,可 以 查看 Excel 表 book. xls 的 生成 结果 ,如 图 4-11 所 示 。 


4-11 预览 数据 


@ 保存 文件 。 单 击 * 下 一 步 "按钮 ,进入 "保存 "对话 框 ,如 图 4-12 所 示 。 选 中 “立即 运 
行 " 复 选 框 ,将 立即 运行 包 。 若 选中 “保存 SSIS 包 ” 复 选 框 , 则 保存 包 以 便 日 后 运行 (选择 
SQL Server 单 选 按钮 可 以 将 包 保 存 到 Microsoft SQL Server msdb 数据 库 ,选择 “文件 系 
统 ” 单 选 按钮 可 以 将 包 保存 为 扩展 名 为 dtsx 的 文件 ) 。 


加 sQL server 导入 和 导出 向 导 = x 


人 [a 


订立 有 Ma 行 (V) 
厂 保存 SSTs 也 (s) 
SAL Server (Q) 


个 文件 系统 (7) 


者 助 00 < 上 一步 (8) 完成 (1) »| 取消 
图 4-12 保存 并 运行 文件 


@ 完成 。 单 击 “ 下 一 步 "按钮 ,进入 “完成 该 向 导 ” 页 面 ,如 图 4-13 所 示 。 单 击 “ 完 成 ” 按 
钮 ,进入 “执行 成 功 ” 页 面 ,如 图 4-14 所 示 , 表 明 数 据 库 表 book 成 功 导 入 为 一 个 Excel 表 
book. xls, 单 击 “ 关 闭 ” 按 钮 。 


甩 SQL Server 导入 和 有 导出 向 导 = 0 Xx 


完 
Le 完成 少时 hasygasiamfe 直 。 交 " 
" 


单 击 “ 完 成 ”以 执行 下 列 操作 : 


ED 
目标 位 置 : D: \SQL 2016\book xls 
目标 提供 程序 :Mierosoft. Jet. 0LEDB.4.0 


|。 将 [dbo]. [book] 中 的 行 复制 | “book 
将 创建 新 的 目标 表 。 


|” “将 不 保存 此 世 。 
|。 ”此 外 将 立即 运行 。 


| 提供 程序 映射 文件 : C:\Program Files (x86) Wtiorosoft SQL Server\i30\DTSVsppinefilesVISSqlToJet4 OL. 


者 助 00 < 上 -so | sm | mm | ws | 
[et | 


图 4-13 完成 该 向 导 
表 和 履 据 完整 性 


世上 油 
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查看 数据 。 可 以 在 前 面 指定 的 文件 夹 中 查找 Excel 表 book. xls, 可 以 浏览 转换 的 
数据 。 


央 SQL Server 导入 和 导出 向 导 = 口 x 
执行 成 功 v 
EA 
eC 
11 总 计 0 错误 
©@ 成 功 11 成 功 0 警告 
详细 信息 (D): 
| | 操作 村 消息 
加 正在 初始 化 歼 据 流 任务 成 
加 正在 初始 化 连接 成 功 
回 正在 设置 SQL 命令 成 功 
加 正在 设置 源 连接 成 功 
加 正在 设置 目标 连接 成 功 
加 正在 验证 成 功 
加 准备 执行 成 功 
回 执行 之 前 成 功 
回 正在 执行 成 功 
中 正在 夏 制 到 “book 成 功 已 传输 5 行 
回 执行 之 后 成 功 
停止 (S) 报告 (R) 。 
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1. 选择 题 
(1) 在 Transact-SQL 语句 中 ,可 以 匹配 0 个 到 多 个 字符 的 通配符 是 入 
A. * B. % CY I 一 
(2) SQL Server 2016 提供 的 单行 注释 语句 是 使 用 开始 的 一 行内 容 。 
在 .了 六 B. 一 一 Gt D:/ 
(3) 在 SQL Server 2016 中 ,局 部 变量 前 面 的 字符 为 E 
A. * B. # C. @@ D. @ 
(4) 若 要 计算 表 中 数据 的 平均 值 , 可 以 使 用 的 函数 是 。 
A. SQRTO B. AVGO C. SQUAREO) D. COUNTO 


(5) 语句 “SELECT DATENAME( MONTH , getdate()) AS 'Month Name'” 的 输出 

结果 为 
A. Month Name B. 当前 日 期 C. 当前 月 份 D. 当前 时 间 

答案 : ABDBC 

2. 思考 题 

(1) Transact-SQL 的 语言 要 素 有 哪些 ? 主要 作用 是 什么 ? 

【 答 】 Transact-SQL 语言 的 要 素 及 其 主要 用 途 如 下 。 

@ 标识 符 。 标 识 符 是 用 于 命名 表 视图、 存储 过 程 等 数据 库 对 象 以 及 常量 、 变 量 、 自 定 
义 函 数 名 称 。 

@ 常量 。 表 示 一 个 特定 数据 值 的 符号 ,其 格式 取决 于 它 所 表示 的 值 的 数据 类 型 。 

@ 变量 。 一 种 是 用 户 自 己 定义 的 局 部 变量 ,另外 一 种 是 系统 提供 的 全 局 变量 。 用 于 存 
储 某 过 程 中 可 以 变化 的 值 。 

@ 注释 。 程 序 代码 中 非 可 执行 的 文本 字符 串 ,增加 程序 的 可 读 性 。 

@ 运算 符 。 用 来 执行 算术 运算 .字符 串 连 接 、 赋 值 以 及 在 字段 .常量 和 变量 之 间 进 行 比 
较 的 操作 符 。 

@) 也 数 。 能 够 返回 一 个 值 的 程序 段 。 

@ 表达 式 。 指 符号 和 运算 符 的 组 合 ,其 计算 结果 为 单个 数据 值 。 

@@ Transact-SQL 语句 的 主要 功能 是 创建 和 管理 数据 库 对 象 . 插 入 、 检 索 、 修 改 和 删除 
数据 ,并 实现 服务 器 和 客户 端的 操作 和 管理 。 

(2) 如 何 定义 变量 ? 如 何 给 变量 赋值 ? 

【 答 】 定义 变量 需要 使 用 DECLARE 命令 ,局 部 变量 定义 时 要 在 其 名 称 前 加 上 标志 
@@ ,定义 全 局 变量 时 必须 以 标记 符 @@ 开 头 。 
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为 变量 赋值 需要 使 用 SET 和 SELECT 命令 。SET 命令 一 次 只 能 为 一 个 变量 赋值 ， 
SELECT 命令 可 以 同时 为 多 个 变量 赋值 。 

(3) 流程 控制 语句 包括 哪些 类 型 ? 各 自 的 作用 是 什么 ? 

【 答 】 控制 流 语 句 主 要 包括 IF…ELSE 选择 语句 .BEGIN…END 语句 块 .WHILE 循 
环 语 句 和 CASE 多 分 支 语 句 。 还 有 批 处 理 的 结束 语句 Go, 向 客户 端 返回 用 户 定 义 消 息 的 
PRINT 语句 ,使 程序 直接 跳 到 指定 的 标 有 标识 符 的 位 置 处 继续 执行 的 GOTO 语句 ,用 于 暂 
时 停止 执行 SQL 语句 语句 块 或 者 存储 过 程 等 的 WAITFOR 语句 ,无 条 件 地 终止 一 个 查 
询 、 存 储 过 程 或 者 批 处 理 的 RETURN 语句 ,以 及 具有 异常 处 理 功能 的 TRY…CATCH 语 
句 等 。 

Transact-SQL 提供 的 控制 流 语 句 主 要 用 于 控制 程序 的 顺序 .选择 和 循环 流程 。 

(4) 简 述 聚合 函数 的 特点 和 用 途 。 

【 答 】 聚合 函数 用 于 对 一 组 值 进行 计算 并 返回 一 个 单一 的 值 。 除 了 COUNT 函数 之 
外 ,其 他 聚合 函数 忽略 空 值 。 聚 合 函 数 经 常 与 SELECT 语句 的 GROUP BY 子 句 一 同 使 
用 。 聚 合 函数 的 作用 是 在 结果 集中 通过 对 被 选 列 值 的 收集 处 理 , 返 回 一 个 数值 型 的 计算 
结果 。 

(5) Transact-SQL 语句 共 分 为 几 类 ? 各自 的 主要 功能 是 什么 ? 

【 答 】 Transact-SQL 语言 的 4 种 类 型 及 其 主要 作用 如 下 。 

QO@ 数据 定义 语言 。 数 据 库 对 象 的 创建 ,修改 和 删除 等 都 可 以 通过 使 用 数据 定义 语言 中 
的 CREATE、ALTER、DROP 等 语句 来 完成 。 

@ 数据 操纵 语言 。 用 于 检索 和 操作 数据 的 SQL 语句 的 子 集 。 数 据 操纵 语言 是 指 用 来 
查询 、 添 加、 修改 和 删除 数据 库 中 数据 的 语句 , 这些 语句 包括 SELECT、INSERT、 
UPDATE、DELETE 等 命令 。 

@ 数据 控制 语言 。 用 来 设置 或 更 改 数 据 库 用 户 或 角色 权限 的 语句 ,包括 GRANT、 
DENY ,REVOKE 等 命令 。 

@ 控制 流 语句 。 用 于 控制 SQL 请 句 、 语 句 块 或 者 存储 过 程 的 执行 流程 。 流 程控 制 语 
句 包括 BEGIN…END JIF…ELSE、WHILE、BREAK、.GOTO、WAITFOR、RETURN 等 
语句 。 

3. 上 机 练习 题 

(1) 利用 Transact-SQL 语句 声明 一 个 长 度 为 16 的 nchar 型 变量 bookname, 并 赋 初 值 
为 “SQL Server 数据 库 编 程 ”。 

【 答 】 变量 bookname 的 声明 和 赋值 代码 如 下 。 

DECLAER (@bookname nchar(16) 

SET (@bookname = 'SQL Server 数据 库 编程 ' 

(2) 编程 计算 任意 两 个 日 期 的 时 间 差 。 

【 答 】 常用 的 计算 两 个 日 期 的 时 间 差 的 代码 如 下 。 

USE test01 

GO 


SET NOCOUNT ON 
DECLARE @startdate datetime, @enddate datetime 


SET @startdate = '1/7/2017 12:12 MM' 

SET @enddate = '11/10/2018 12:00 MM 

SELECT DRTEDIFF(year, @ startdate, @enddate) 

SELECT DATEDIFF (month, @ startdate, @enddate) 

SELECT DATEDIFF(day, @ startdate, @enddate) 

SELECT DATEDIFF(minute, @startdate, '1/8/2019 12:17 AM') 
SELECT DATEDIFF(minute, @ startdate, GETDRTE() ) 

SET NOCOUNT OFF 

G0 


(3) 编程 求 50 一 100 中 所 有 能 被 3 整除 的 奇数 之 和 。 
【 答 】 程序 代码 如 下 。 


DECLARE @count INT, @SUM INT 
SET @count = 51 
SET @SUM=0 
WHILE @count <= 100 
BEGIN 
IF (CEILING(@count/3.0)<= FLOOR(@count/3.0)) 
BEGIN 
SET @SUM = @SUM + @count 
END 
SET @count = @count+ 2 
END 
PRINT '50 一 100 中 所 有 能 被 3 整除 的 奇数 之 和 ' + CAST( @SUM AS NCHAR(4)) 
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1. 选择 题 
(1) SELECT 语句 中 使 用 关键 字 可 以 将 重复 行 屏蔽 。 

A. order by B. having C. top D. distinct 
(2) SELECT 语句 中 的 子 句 用 于 存放 结果 集 到 表 中 。 

A. select B. into C. from D. group by 
(3) SELECT 语句 中 的 子 句 只 能 配合 group by 子 句 使 用 。 

A. order by B. having C. into D. compute 
(4) 使 用 空 值 查询 时 ,表示 一 个 列 RR 不 是 空 值 的 表达 式 是 o 

A. RR IS NULL B. RR== NULL 

C. RR<>NULL D. RR IS NOT NULL 
(5) 表达 式 中 存在 LIKE 运算 时 ,表达 式 的 结果 可 能 是 类 型 数据 。 

A. date B. float C. int D. table 
答案 : DBBDA 
2. 思考 题 


(1) 简 述 SELECT 语句 中 各 个 子 句 的 作用 。 

【 答 】 SELECT 语句 中 各 个 子 句 的 作用 如 下 。 

Q@ SELECT: 描述 结果 集 的 列 , 是 一 个 用 逗号 分 隔 的 表达 式 列 表 。 

@ INTO: 指定 使 用 结果 集 来 创建 新 表 。 

@ FROM: 包含 从 中 检索 到 结果 集 数据 的 源 表 的 列表 。 

四 WHERE: 定义 源 表 中 的 行 要 满足 SELECT 语句 的 要 求 所 必须 达到 的 条 件 。 

@ GROUP BY: 根据 分 组 表达 式 的 值 将 结果 集 分 成 组 。 

@ WITH ROLLUP 与 GROUP BY 一 起 时 用 于 总 体 统计 。 

@ HAVING: 对 结果 集 的 附加 筛选 。HAVING 子 句 通常 与 GROUP BY 子 句 一 起 
使 用 。 

@ ORDER BY: 定义 结果 集中 行 排列 的 顺序 。 

(2) 说 明 在 SELECT 语句 中 使 用 聚合 函数 应 该 注意 的 问题 。 

【 答 】 聚集 函数 是 用 于 获取 累计 值 的 函数 ,不 能 被 用 于 SELECT 语句 的 WHERE 子 
句 中 。 利 用 GROUP BY 子 句 时 ,输出 项 只 能 是 GROUP BY 后 的 分 组 列 和 聚合 函数 。 聚 合 
函数 可 以 出 现在 HAVING 中 。 


(3) SQL 脚本 执行 的 结果 有 哪 几 种 形式 ? 查看 SQL 脚本 的 方法 有 哪些 ? 

【 答 】 选择 输出 格式 可 以 通过 工具 栏 方式 ,也 可 以 通过 选择 菜单 中 的 “查询 ~“ 将 结果 
保存 到 ”命令 方式 。SQL 脚本 执行 的 结果 通常 有 如 下 三 种 形式 : 以 文本 格式 显示 结果 、 以 网 
格 显示 结果 及 将 结果 保存 到 文件 。 

查看 SQL 脚本 的 方法 可 以 通过 查询 设计 器 进行 ,也 可 以 通过 文本 方式 进行 。 

(4) 将 NULL 与 其 他 值 比较 会 产生 什么 结果 ? 数值 列 中 存在 NULL 会 产生 什么 结果 ? 

【 答 】 涉及 空 值 的 查询 用 NULL 来 表示 。 一 个 列 值 是 空 值 或 者 不 是 空 值 ,不 能 表示 
为 =NULL 或 二 >NULL, 而 要 表示 为 IJS NULL 或 IS NOT NULL。 将 NULL 与 其 他 值 比 
较 , 其 结果 也 是 真 或 假 。 

数值 列 中 存在 NULL 值 ,表示 数值 不 确定 。 

3. 上 机 练习 题 ( 本 题 利 用 teaching 数据 库 进 行 操作 ) 

(1) 查询 course 表 中 的 所 有 记录 。 

【 答 】 程序 代码 如 下 。 


select * from course 

go 

(2) 查询 student 表 中 女生 的 人 数 。 
【 答 】 程序 代码 如 下 。 


select * from student 

Where sex= ' 女 ' 

go 

(3) 查询 teacher 表 中 每 一 位 教授 的 教师 号 、 姓 名 和 专业 名 称 。 
【 答 】 程序 代码 如 下 。 


select teacherno, tname, major from teacher 

where prof = ' 教 授 ' 

go 

(4) 按 性 别 分 组 , 求 出 student 表 中 每 组 学 生 的 平均 年 龄 。 
【 答 】 程序 代码 如 下 。 


select sex as ' 学 生性 别 '，avg(DATEDIFF(year, birthdate, getdate( ))) 
as ' 平 均 年 龄 ' 
from student 
group by sex 
go 
(5) 利用 现 有 的 表 生 成 新 表 , 新 表 中 包括 学 号 、 学 生 姓名 、 课 程 号 和 总 评 成 绩 。 其 中 : 
总 评 成 绩 一 final * 0. 8 十 daily * 0. 2。 
【 答 】 程序 代码 如 下 。 
select student. studentno, student. sname, score. courseno, 
final* 0.8+daily* 0.2as ' 总 评 ' 


into stu_sorse 
from student, score 
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where student. studentno = score. studentno 
go 

Select * from stu sorse 

go 


(6) 统计 每 个 学 生 的 期 末 成 绩 平均 分 。 
【 答 】 程序 代码 如 下 。 


select studentno, sname, avg( 总评 ) 
from stu_sorse 

group by studentno, sname 

go 


(7) 输出 student 表 中 年 龄 最 大 的 男生 的 所 有 信息 。 
【 答 】 程序 代码 如 下 。 


select * from student 
where birthdate = (select min(birthdate) from student) 
go 


/* 

select top 1 * from student 
order by birthdate 

*/ 


(8) 查询 teacher 表 中 没有 职称 的 职工 的 教师 号 、 姓 名 、 专 业 和 部 门 。 
【 答 】 程序 代码 如 下 。 


select teacherno, tname, major, department 
from teacher 

where prof is NULL 

go 


第 7 章 Transact-SQL 语句 的 高 级 应 用 


1. 选择 题 
(1) SQL Server 2016 的 多 表 连 接 中 是 默认 连接 。 

A. 内 连接 B. 笛 卡 儿 连 接 C. 左 连 接 D. 布 连 接 
(2) 子 查询 是 一 个 戏 套 查询 ,但 不 能 在 请 名 进行 储 套 。 

A. select B. insert C. create D. delete 
(3) 游标 利用 FETCH 语句 获取 结果 集 信息 时 ,不 包括 选项 。 

A. next B. last C. first D. before 
(4) 使 用 游标 处 理 结果 集 时 ,其 基本 过 程 不 包括 步 又 。 

A. 打开 游标 B. 关闭 游标 C. 游标 嵌 套 D. 释放 游标 
(5) SQL Server 2016 的 多 表 连 接 中 没有 连接 条 件 。 

A. 内 连接 B. 笛 卡 儿 连 接 C. 完全 连接 D. 外 连接 
答案 : ACDCB 
2. 思考 题 


(1) 简 述 如 何 利用 游标 处 理 结果 集 。 

【 答 】 利用 游标 处 理 结果 集 ,主要 包括 如 下 步骤 。 

@ 声明 游标 。 在 使 用 游标 之 前 ,首先 需要 声明 游标 。 

@ 打开 游标 。 打 开 一 个 游标 意味 着 在 游标 中 输入 了 相关 的 记录 信息 。 

@ 获取 记录 信息 。 使 用 Fetch 语句 可 以 获取 结果 集 的 行 值 ,一 条 Fetch 语句 会 执行 两 
步 操作 : 首先 将 游标 当前 指向 的 记录 保存 到 一 个 局 部 变量 中 ,然后 游标 将 自动 移 向 下 一 条 
记录 。 将 一 条 记录 读 和 人 某 个 局 部 变量 后 ,就 可 以 根据 需要 对 其 进行 处 理 了 。 

@ 关闭 游标 。 可 以 释放 那些 被 该 游标 锁定 的 记录 集 。 

@ 释放 游标 。 释 放 游 标 自身 所 占用 的 资源 。 

(2) 简 述 将 文本 格式 的 数据 导入 数据 库 表 中 的 过 程 。 

【 答 】 向 数据 表 中 导入 结构 化 的 文本 文件 (如 txt 文件 ) ,可 以 利用 BULK INSERT 
命令 。 
@ 创建 一 个 文本 文件 (如 test101. txt') 并 将 数据 利用 指定 格式 符 ( 如 */”) 进 行 分 隔 排 
列 , 文 件 内 容 如 : 

1025121107/ 梁 欣 /c05109/62.00 


1137221508/ 那 冬 /c08106/95. 00 
1137221508/ 平 钒 /c08123/89.00 
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@ 使 用 BULK INSERT 命令 将 文件 中 的 记录 直接 插入 到 指定 数据 表 中 。 例 如 ,使 用 
BULK INSERT 的 具体 代码 如 下 所 示 : 

BULK INSERT st_score 

FROM 'D:\sqlpro\test101. txt ' 

WITH (FIELDTERMINATOR = '/') 

(3) 比较 多 表 连 接 与 子 查询 的 优 缺点 。 

【 答 】 表 连 接 与 子 查询 的 优 缺 点 简 述 如 下 。 

@ 多 表 连 接 : SQL Server 处 理 连接 时 ,查询 引擎 从 多 种 可 能 的 方法 中 选择 最 高 效 的 方 
法 处 理 连 接 。 连 接 条 件 中 用 到 的 列 不 必 具 有 相同 的 名 称 或 相同 的 数据 类 型 。 但 是 如 果 数 据 
类 型 不 相同 , 则 必须 兼容 或 可 进行 隐 性 转换 。 如 果 不 能 隐 性 转换 数据 类 型 , 则 连接 条 件 必 须 
用 CAST 函数 显 式 地 转换 数据 类 型 。 

连接 操作 增强 了 查询 的 可 读 性 。 

@ 子 查询 : SQL Server 2016 对 谍 套 查询 的 处 理 过 程 是 从 内 层 向 外 层 处 理 , 即 先 处 理 
最 内 层 的 子 查询 ,然后 把 查询 的 结果 用 于 其 外 查询 的 查询 条 件 , 再 层 层 向 外 求解 ,最 后 得 出 
查询 结果 。 

对 于 多 层 子 查询 ,可 读 性 相对 于 连接 要 差 一 些 。 

一 般 情 况 下 ,包含 子 查询 的 查询 语句 可 以 写成 连接 查询 的 方式 。 在 有 些 方面 ,连接 的 性 
能 要 优 于 子 查询 ,原因 是 连接 不 需要 查询 优化 器 执行 排序 等 额外 的 操作 。 

3. 上 机 练习 题 ( 本 题 利用 teaching 数据 库 进 行 操作 ) 

(1) 查询 每 一 位 教授 的 教师 号 、 姓 名 和 讲授 的 课程 名 称 。 

【 答 】 程序 代码 如 下 。 


select teacher. teacherno, tname, major, course. cname 
from teacher, course teach class 
where prof = ' 教 授 ' 
and teacher. teacherno = teach class. teacherno 
and teach class. courseno = course. courseno 
go 
(2) 利用 现 有 的 表 生 成 新 表 ,新 表 中 包括 学 号 ,学 生 姓名 .课程 名 称 和 总 评 成 绩 。 其 中 : 
总 评 成 绩 ==final * 0. 9 十 daily * 0. 1。 
【 答 】 因为 有 4 个 源 表 , 表 间 至 少 需 要 三 个 连接 条 件 , 此 处 只 有 两 个 连接 条 件 , 则 表 间 
存在 笛 卡 儿 连 接 ,可 以 通过 distinct 子 句 将 结果 集中 的 重复 行 删除 。 程 序 代 码 如 下 : 
select distinct student. studentno, student. sname, course.cname, 
score. final * 0.9 + score. daily* 0.1 as ' 总 评 ' 
into stu_ course 
from student, course, teach class, score 
where student. studentno= score. studentno 
and course. courseno = score. courseno 
go 
(3) 统计 每 个 学 生 的 期 末 成 绩 高 于 75 分 的 课程 门 数 。 
【 答 】 程序 代码 如 下 。 


select student. studentno, student. sname, count( * ) as “课程 门 数 ' 
from student, score 
where score.final > 75 and student. studentno = score. studentno 
group by student. studentno, student. sname 
go 


(4) 输出 student 表 中 年 龄 大 于 女生 平均 年 龄 的 男生 的 所 有 信息 。 
【 答 】 程序 代码 如 下 。 


select * from student 

where sex= ' 男 ' 

and datediff(year,birthdate,getdate()) > ( 
select avg(datediff (year, birthdate, getdate( ))) 
from student 
where sex= ' 女 ' 

) 

go 


(5) 计算 每 个 学 生 获 得 的 学 分 (以 16 学 时 记 为 1 学 分 )。 
【 答 】 程序 代码 如 下 。 


select student. studentno, student. sname, sum(period/16) 
from student INNER JOIN score 

ON student. studentno = score. studentno 

INNER JOIN course 

ON course. courseno = score. courseno 
where score.final>60 
group by student. studentno, student. sname 
go 


(6) 获取 入 学 时 间 为 2017 一 2018 年 的 17 级 学 生 中 入 学 年 龄 小 于 19 岁 的 学 生 的 学 号 、 
姓名 及 所 修 课程 的 课程 名 称 。 
【 答 】 程序 代码 如 下 。 


select student. studentno, student. sname, stu_course. cname 
from student inner join stu course 
on student. studentno = stu_course. studentno 
where (substring( student. studentno,1,2) = '17°' 
and (datediff (year, birthdate, '2017— 01 ~ 01')<19)) 
or( substring( student. studentno,1,2) = '16" 
and (datediff (year, birthdate, '2016— 01-01')<19)) 


go 


(7) 查询 18 级 学 生 的 学 号 、 姓 名 、 课 程 名 及 学 分 。 
【 答 】 程序 代码 如 下 。 


select student. studentno, student. sname, stu_course. cname 
from student inner join stu course 

on student. studentno = stu_course. studentno 
where substring(student. studentno,1,2)= '18 
go 
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(8) 查询 选修 课程 少 于 3 门 ,或 期 末 成 绩 含 有 60 分 以 下 课程 的 学 生 的 学 号 、 姓 名、 电话 
和 Email。 
【 答 】 程序 代码 如 下 。 


Select ”studentno, count( * ) as 'countNUM ' 
into countl 
from score 
group by studentno 
GO 
select student. studentno, sname, phone, Email 
from student inner join score 
on student. studentno = score. studentno 
inner join count1 
on student. studentno = count1. studentno 
where score.final <60 and countNUM<3 
go 


第 8 章 索引 和 视图 


1. 选择 题 
(1) 在 SQL Server 2016 中 ,索引 的 顺序 和 表 中 记录 的 物理 顺序 相同 的 索引 
是 
A. 主键 索引 B. 非 聚 集 索引 C. 聚集 索引 D. 唯一 索引 
(2) 下 面 对 索 引 的 相关 描述 正确 的 是 
A. 经 常 被 查询 的 列 不 适合 建 索引 B. 小 型 表 适 合 建 索引 
C. 有 很 多 重复 值 的 列 适 合 建 索引 D. 是 外 键 或 主键 的 列 不 适合 建 索引 
(3) 在 使 用 CREATE INDEX 命令 创建 索引 时 , FILLFACTOR 选项 定义 的 
是 5 
A. 填充 因子 B. 误 码 率 
C. 元 余 度 D. 索引 页 的 填充 率 
(4) 对 视图 的 描述 错误 的 是 


A. 视图 是 一 张 虚拟 表 
B. 视图 定义 包含 TOP 子 句 时 才能 设置 排序 规则 
C. 可 以 像 查询 表 一 样 来 查询 视图 
D. 被 修改 的 视图 只 能 引用 一 个 基 表 的 列 
(5) WITH CHECK OPTION 属性 对 视图 的 用 途 是 进行 


A. 检查 约束 B. 删除 监测 
C. 更 新 监测 D. 插入 监测 
答案 : CCADA 
2. 思考 题 


(1) 简 述 创建 索引 的 必要 性 。 

【 答 】 创建 索引 可 以 大 大 提高 系统 的 查询 性 能 ,具体 表现 在 如 下 方面 。 

@ 加 快 数据 的 检索 速度 。 

@ 通过 创建 唯一 性 索引 ,可 以 保证 每 一 行 数据 的 唯一 性 。 

@ 加 速 表 与 表 之 间 的 连接 ,特别 是 实现 数据 的 参照 完整 性 方面 具有 特别 的 意义 。 

@ 在 使 用 ORDER BY 和 GROUP BY 子 句 进行 数据 检索 时 ,可 以 显著 减少 查询 中 分 
组 和 排序 的 时 间 。 

@O 通过 使 用 索引 ,可 以 在 查询 过 程 中 使 用 查询 优化 器 ,提高 系统 性 能 。 

(2) 按照 索引 的 存储 结构 划分 ,索引 分 为 哪 几 种 ? 各 有 什么 特点 ? 

【 答 】 根据 索引 的 存储 结构 可 将 索引 分 为 两 类 ,其 具体 特点 如 下 。 
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O@ 聚集 索引 。 索 引 键 值 的 顺序 与 数据 表 中 记录 的 物理 顺序 相同 , 即 聚集 索引 决定 了 数 
据 库 表 中 记录 行 的 存储 顺序 。 由 于 记录 行 只 能 按 一 个 物理 顺序 存储 ,因此 每 个 表 只 能 有 一 
个 聚集 索引 。 

@ 非 聚集 索引 。 非 聚集 索引 具有 独立 于 数据 行 的 结构 ,索引 与 数据 分 别 存储 ,索引 表 
仅 包含 指向 数据 表 的 指针 。 在 一 个 表 中 可 创建 多 个 非 聚集 索引 。 

(3) 简 述 基 表 和 视图 之 间 的 关系 。 

【 答 】 视图 是 从 一 个 或 多 个 基本 表 导 出 的 虚 表 , 它 的 数据 并 不 存储 在 数据 库 中 ,视图 中 
的 数据 来 自 定义 视图 的 查询 所 引用 的 表 。 视 图 的 查询 可 像 基 本 表 一 样 参与 数据 库 操作 ,但 
视图 的 更 新 最 终 落实 到 有 关 基 本 表 的 更 新 上 。 

(4) 简 述 创建 视图 的 必要 性 。 

【 答 】 创建 视图 的 必要 性 分 析 如 下 。 

Oa 将 数据 集中 显示 ,简化 用 户 的 数据 查询 和 处 理 。 

@ 简化 数据 操作 ,将 数据 库 的 设计 和 用 户 的 使 用 分 离开 来 ,屏蔽 数据 库 的 复杂 性 。 

@ 重新 定制 数据 ,使 得 数据 便于 共享 。 

@ 组 合 分 区 数据 ,可 将 来 自 不 同 表 的 多 个 查询 结果 组 合成 单一 的 结果 集 , 以 便 用 户 查 
询 和 使 用 。 

@ 简化 用 户 权 限 的 管理 ,增强 了 安全 性 。 

(5) 简 述 统计 信息 的 作用 。 

【 答 】 SQL Server 2016 的 查询 优化 器 在 执行 查询 时 会 自动 对 查询 语句 进行 优化 ,从 
而 产生 一 个 最 佳 的 执行 计划 ,该 计划 将 以 最 小 的 执行 成 本 来 获得 结果 。 优 化 过 程 中 将 使 用 
表 、 索 引 或 视图 的 统计 信息 。 根 据 统计 信息 ,查询 优化 器 就 可 以 决定 在 执行 时 是 否 使 用 
索引 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进行 操作 ) 

(1) 在 course 表 的 cname 列 上 创建 非 聚 集 索 引 IDX_cname。 

【 答 】 程序 代码 如 下 。 

USE teaching 

GO 

CREATE NONCLUSTERED INDEX IDX_cname ON course(cname) 

GO 

(2) 在 student 表 的 studentno 和 classno 列 上 创建 唯一 索引 UQ_stu, 若 该 索引 已 存 
在 , 则 删除 后 重建 。 并 输出 student 表 中 的 记录 .查看 输出 结果 的 顺序 。 

【 答 】 程序 代码 如 下 。 

IF EXISTS(SELECT name FROM sysindexes WHERE name = 'UQ_stu') 

DROP INDEX student.UQ stu 
GO 
CREATE NONCLUSTERED INDEX UQ_stu ON student( studentno, classno) 


GO 
SELECT * FROM student 


(3) 修改 UQ_stu 的 索引 属性 , 当 执行 多 行 插入 操作 时 出 现 重 复 键 值 , 则 忽略 该 记录 ， 
且 设置 填充 因子 为 80%。 
【 答 】 程序 代码 如 下 。 


ALTER INDEX UQ stu ON student REBUILD 
WITH (PAD INDEX = ON, FILLFACTOR = 80, IGNORE DUP KEY = ON) 
GO 


(4) 创建 一 个 视图 v_teacher ,查询 所 有 “计算 机 学 院 ” 教 师 的 信息 。 
【 答 】 程序 代码 如 下 。 


CREATE VIEW v_teacher 

RS 

SELECT * 

FROM teacher 

WHERE department = ' 计 算 机 学 院 ' 
G60 

SELECT * FROM v_ teacher 


(5) 创建 一 个 视图 v_avgstu, 查 询 每 个 学 生 的 学 号 、 姓 名 及 平均 分 ,并 且 按 照 平均 分 降 
序 排序 。 
【 答 】 程序 代码 如 下 。 


CREATE VIEW v_avgstu 

RS 

SELECT TOP(100) PERCENT student. studentno, 
student. sname，RVG( score. final) AS 'average' 

FROM student, score 

WHERE student. studentno = score. studentno 
AND score. final IS NOT NULL 

GROUP BY student. studentno, student. sname 

ORDER BY AVG( score. final) DESC 

GO 

SELECT * FROM v_avgstu 


(6) 修改 v_teacher 的 视图 定义 ,添加 WITH CHECK OPTION 选项 。 
【 答 】 程序 代码 如 下 。 

ALTER VIEW v_teacher 

RS 

SELECT * FROM teacher 

WHERE department = ' 计 算 机 学 院 ' 

WITH CHECK OPTION 

GO 


(7) 通过 视图 v_teacher 向 基 表 teacher 中 分 别 插入 数据 ('t05039',' 张 声 月 ', 计算机 应 
用 ', ' 讲 师 ', ' 计 算 机 学 院 ') 和 ('t06018'，' 李 诚 ', ' 机 械 制造 '，' 副 教授 ', "机 械 学 院 ') ,并 查看 
插入 数据 情况 。 

【 答 】 程序 代码 如 下 。 


翰 吕 溃 


索引 和 视图 
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INSERT INTO v_teacher 
VALUES( 't05039', ' 张 声 月 ', "计算 机 应 用 ', ' 讲 师 ', ' 计 算 机 学 院 ') 
INSERT INTO v_teacher 
VALUES( 't06018，' 李 诚 '， 机 械 制 造 ' 副教授， 机 械 学 院 ') 
GO 
SELECT * FROM v_teacher 
SELECT * FROM teacher 


(8) 通过 视图 v_teacher 将 基 表 teacher 中 教师 编号 为 105039 的 教师 职称 修改 为 “ 副 
教授 。 
【 答 】 程序 代码 如 下 。 


UPDATE v_teacher 


SET prof = ' 副 教授 ' 
WHERE teacherno = 't05039" 
GO 


SELECT * FROM teacher 


第 9 章 存储 过 程 与 触发 器 


1. 选择 题 
(1) 存储 过 程 是 SQL Server 服务 器 的 一 组 预先 定义 并 的 Transact-SQL 
语句 。 
A. 保存 B. 编译 C. 解释 D. 编写 
(2) 下 面 有 关 存 储 过 程 的 叙述 错误 的 是 。 


A. SQL Server 允许 在 存储 过 程 创建 时 引用 一 个 不 存在 的 对 象 
B. 存储 过 程 可 以 带 多 个 输入 参数 ,也 可 以 带 多 个 输出 参数 

C. 使 用 存储 过 程 可 以 减少 网 络 流量 

D. 在 一 个 存储 过 程 中 不 可 以 调用 其 他 存储 过 程 


(3) 使 用 EXECUTE 语句 执行 存储 过 程 时 ,在 情况 下 可 以 省 略 该 关键 。 
A. CREATE 语句 之 后 的 B. DECLARE 语句 之 后 的 
C. 为 批 处 理 的 第 一 条 语句 时 的 D. 任何 

(4) 下 面 有 关 触 发 器 的 叙述 错误 的 是 。 


A. 触发 器 是 一 个 特殊 的 存储 过 程 
B. 触发 器 不 可 以 引用 所 在 数据 库 以 外 的 对 象 
C. 在 一 个 表 上 可 以 定义 多 个 触发 器 
D. 触发 器 在 check 约束 之 前 执行 
(5) SQL Server 为 每 个 触发 器 创建 的 两 个 临时 表 是 


A. selected 和 deleted B. deleted 和 updated 
C. inserted 和 updated D. inserted 和 deleted 
答案 : BDCBD 
2. 思考 题 


(1) 什么 是 存储 过 程 ? 使 用 存储 过 程 有 什么 好 处 ? 

【 答 】 SQL Server 2016 中 存储 过 程 是 用 于 完成 某 项 任务 的 Transact-SQL 语句 , 它 可 
以 接受 参数 .返回 参数 值 和 状态 值 。 使 用 存储 过 程 有 如 下 好 处 : 

@ 提供 了 SQL Server 服务 器 处 理 复 杂 任 务 的 能 力 。 

@) 增强 了 Transact-SQL 语句 代码 的 重用 性 和 共享 性 。 

@ 减少 了 网 络 中 数据 的 流量 。 

@ 加 快 了 SQL Server 系统 的 运行 速度 。 
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@ 加 强 了 SQL Server 系统 的 安全 性 。 

(2) 一 个 存储 过 程 需 要 修改 但 又 不 希望 影响 现 有 的 权限 ,应 使 用 哪个 语句 来 进行 修改 ? 

【 答 】 应 该 使 用 ALTER PROCEDURE 语句 对 存储 过 程 进行 修改 。ALTER PROCEDURE 
语句 修改 存储 过 程 时 ,不 会 影响 权限 ,也 不 影响 相关 的 存储 过 程 或 触发 器 。 

(3) 什么 是 触发 器 ? 其 主要 功能 是 什么 ? 

【 答 】 触发 器 是 一 种 特殊 类 型 的 存储 过 程 , 是 在 用 户 对 某 一 表 中 的 数据 进行 
UPDATE INSERT 和 DELETE 操作 时 被 触发 执行 的 一 段 程序 。 

触发 器 可 以 实现 由 主键 和 外 键 所 不 能 保证 的 复杂 的 参照 完整 性 和 数据 一 致 性 。 其 主要 
作用 体现 在 如 下 几 个 方面 : 

@ 和 触发 器 可 以 对 数据 库 进 行 级 联 修改 。 

@ 实现 比 CHECK 约束 更 为 复杂 的 限制 。 

@ 强制 表 的 修改 要 合乎 业务 规则 。 

(4) AFTER 触发 器 和 INSTEAD OF 触发 器 有 什么 不 同 ? 

【 答 】 AFTER 触发 器 和 INSTEAD OF 触发 器 的 区 别 如 下 。 

Qa 在 执行 了 INSERT、UPDATE 或 DELETE 语句 操作 之 后 执行 AFTER 触发 器 。 它 
只 能 在 表 上 指定 。 一 个 表 可 以 有 多 个 AFTER 触发 器 。 

@ 执行 INSTEAD OF 和 触发 器 代替 通常 的 触发 动作 。 该 类 触发 器 不 但 可 以 在 表 上 定 
义 , 还 可 以 在 具有 一 个 或 多 个 基 表 的 视图 上 定义 。 一 个 表 只 能 具有 一 个 给 定 类 型 的 
INSTEAD OF 触发 器 。 

(5) inserted 表 和 deleted 表 各 起 什么 作用 ? 

【 答 】 inserted 表 存 放 由 于 执行 INSERT 或 UPDATE 语句 而 要 向 表 中 插入 的 所 有 
行 。 而 deleted 表 存 放 由 于 执行 DELETE 或 UPDATE 语句 而 要 从 表 中 删除 的 所 有 行 。 

3. 上 机 操作 题 ( 本 题 利用 teaching 数据 库 中 的 表 进 行 操 作 ) 

(1) 创建 一 个 名 称 为 StulInfo 的 存储 过 程 , 要 求 完 成 以 下 功能 : 在 student 表 中 查询 
18 级 学 生 的 学 号 ` 姓 名 .性别 .出 生日 期 和 电话 5 个 字段 的 内 容 。 

【 答 】 程序 代码 如 下 。 

-查询 是 否 已 存在 此 存储 过 程 ,如 果 存 在 ,就 删除 它 

IF EXISTS (SELECT name FROM sysobjects 

WHERE name = 'StuInfo'AND type = 'P') 
DROP PROCEDURE StuInfo 

GO 

-- 创建 存储 过 程 

CREATE PROCEDURE StuInfo 

RS 

Select studentno, sname, sex, birthdate, phone 

FROM student 

WHERE substring( studentno, 1,2) = '18" 

GO 

(2) 创建 一 个 存储 过 程 ScorelInfo, 完 成 的 功能 是 在 表 student、 表 course 和 表 score 中 
查询 以 下 字段 : 学 号 姓名、 性 别 , 课 程 名 称 、 期 末 分 数 。 

【 答 】 程序 代码 如 下 。 


-- 查 询 是 否 已 存在 此 存储 过 程 ,如 果 存 在 ,就 删除 它 
IF EXISTS (SELECT name FROM sysobjects 
WHERE name = 'ScoreInfo' RND type = 'P') 
DROP PROCEDURE ScoreInfo 
G0 
一 创建 存储 过 程 
CREATE PROCEDURE ScoreInfo 
RS 
Select student. studentno, student. sname, student. sex, 
Course. cname, Score. final 
FROM student, course, score 
WHERE student. studentno = score. studentno 
and score. courseno = course. courseno 
GO 


(3) 创建 一 个 带 有 参数 的 存储 过 程 Stu_Age, 该 存储 过 程 根据 输入 的 学 号 ,在 student 
表 中 计算 此 学 生 的 年 龄 ,并 根据 程序 的 执行 结果 返回 不 同 的 值 ,程序 执行 成 功 返 回 整数 0， 


如 果 执 行 出 错 则 返回 错误 号 。 
【 答 】 程序 代码 如 下 。 


IF EXISTS (SELECT name FROM sysobjects 
WHERE name = 'Stu_Age'AND type = 'P') 
DROP PROCEDURE Stu_Age 
GO 
-- 创建 存储 过 程 
USE teaching 
G0 
CREATE PROCEDURE Stu_Age 
@ studentNO nvarchar(10), @Age int OUTPUT 
RS 
一 定义 并 初始 化 局 部 变量 ,用 于 保存 返回 值 
DECLARE @ErrorValue int 
SET @ErrorValue= 0 


-- 求 此 学 生 的 年 龄 

SELECT @Age = YERR(GETDRTE( ) ) ~ YEAR(birthdate) 
FROM student 

WHERE studentno = @ studentNO 

=-- 根据 程序 的 执行 结果 返回 不 同 的 值 


IF (@@ERROR<> 0) 

SET @ErrorValue = @ @ERROR 
RETURN @ErrorValue 
GO 


(4) 创建 一 个 INSERT 触发 器 TR_Stu_Insert, 当 在 student 表 中 插入 一 条 新 记录 时 ， 


触发 该 触发 器 ,并 给 出 “你 插入 了 一 条 新 记录 !” 的 提示 信息 。 
【 答 】 实现 本 题 的 方法 如 下 。 


@ 在 SQL Server Management Studio 中 展开 teaching 数据 库 , 右 击 student 表 中 的 


“触发 器 "文件 夹 , 从 弹出 的 快捷 菜单 中 选择 “新 建 触发 器 ”命令 。 


@ 选择 菜单 栏 中 的 “查询 ”>“ 指 定 模 板 参 数 的 值 ” 命 令 ,在 “指定 模板 参数 的 值 ? 对 话 框 


疗 储 过 程 与 甬 发 器 


击 属 蛋 


SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 才 指 时 


中 将 参数 Schema_Name 的 值 修 改 为 dbo, 参 数 Trigger_Name 的 值 修 改 为 TR_Stu_Insert， 
参数 Table_Name 的 值 修改 为 student, 参数 Data_Modification_Statements 的 值 修改 为 
INSERT ,然后 单 击 “ 确 定 ”按钮 。 

@ 在 新 建 触发 器 模板 窗口 中 的 BEGIN 和 END 语句 之 间 输 入 以 下 三 条 语句 : 


DECLARE @msg nchar(30) 
SET @nmsg= ' 你 插入 了 一 条 新 记录 !' 
PRINT @msg 


@ 单 击 工具 栏 上 的 “执行 ?按钮 即 可 完成 此 触发 器 的 创建 。 

(5) 创建 一 个 AFTER 和 触发 器 ,要求 实现 以 下 功能 : 在 score 表 上 创建 一 个 插入 、 更 新 
类 型 的 触发 器 TR_ScoreCheck, 当 在 score 字段 中 插入 或 修改 考试 分 数 后 ,触发 该 触发 器 ， 
检查 分 数 是 否 为 0 一 100。 

【 答 】 程序 代码 如 下 。 


CREATE TRIGGER TR_ScoreCheck 
ON score 
FOR INSERT, UPDATE 
RS 
IF UPDATE(final ) 
PRINT 'AFTER 触发 器 开始 执行 ……. 
BEGIN 
DECLARE @ ScoreValue real 
SELECT @ScoreValue = (SELECT final FROM inserted) 
IF @ScoreValue> 100 OR @ScoreValue<0 
PRINT ' 输 入 的 分 数 有 误 , 请 确认 输入 的 考试 分 数 !… 
END 
GO 


(6) 创建 一 个 AFTER 触发 器 ,要 求实 现 以 下 功能 : 在 course 表 上 创建 一 个 删除 类 型 
的 触发 器 TR_NotAllowDelete, 当 在 course 表 中 删除 记录 时 ,触发 该 触发 器 ,显示 不 允许 删 
除 表 中 数据 的 提示 信息 。 

【 答 了 程序 代码 如 下 。 


IF EXISTS(SELECT name FROM sysobjects 
WHERE name = 'TR_NotAllowDelete' AND type = 'TR') 
DROP TRIGGER TR_NotAllowDelete 
GO 
CREATE TRIGGER TR_NotAllowDelete 
ON course 
AFTER DELETE 
RS 
PRINT 'AFTER 触发 器 开始 执行 …" 
PRINT ' 本 表 中 的 数据 不 允许 被 删除 ! 不 能 执行 删除 操作 !" 
GO 


第 10 章 事务 和 锁 


1. 选择 题 
(1) SQL Server 2016 的 事务 不 具有 的 特征 是 

A. 原子 性 B. 隔离 性 C. 一 致 性 D. 共享 性 
(2) SQL Server 2016 中 常见 的 锁 类 型 不 包括 

A. 共享 B. 架构 GC: 三 D. 排他 
(3) 事务 的 隔离 级 别 不 包括 5 

A. READ UNCOMMITTED B. READ COMMITTED 

C. REPEATABLE ONLY D. SNAPSHOT 
(4) 死 锁 发 生 的 原因 是 

A. 并 发 控制 B. 服务 器 故障 C. 数据 错误 D. 操作 失误 
(5) SQL Server 2016 中 发 生死 锁 需 要 。 

A. 用 户 处 理 B. 系统 自动 处 理 。 C. 修改 数据 源 D. 取消 事务 
答案 : DCDAB 
2. 思考 题 


(1) 显 式 事务 、 隐 式 事务 有 什么 区 别 ? 

【 答 】 显 式 事务 和 隐 式 事务 的 区 别 如 下 。 

@ 显 式 事务 是 指 显 式 定义 了 启动 和 结束 的 事务 。 在 实际 应 用 中 ,大 多 数 的 事务 是 由 用 
户 来 定义 的 。 事 务 结束 分 为 提交 (COMMIT) 和 回 深 (ROLLBACK) 两 种 状态 。 事 务 以 提交 
状态 结束 ,全 部 事务 操作 被 完成 且 明 确 的 提交 到 数据 库 中 。 事 务 以 回 滚 的 状态 结束 , 则 事务 
的 操作 被 全 部 取消 ,事务 操作 失败 。 

@ 在 隐 式 事务 中 ,SQL Server 在 没有 事务 定义 的 情况 下 会 开始 一 个 事务 ,但 不 会 像 在 
自动 提交 模式 中 那样 自动 执行 COMMIT 或 ROLLBACK 语句 ,事务 必须 显 式 结束 。 

(2) 如 何 设置 事务 的 隔离 级 别 ? 

【 答 】 事务 可 以 设置 隔离 级 别 ,隔离 级 别 描述 了 一 个 事务 必须 与 其 他 事务 所 进行 的 资 
源 或 数据 更 改 相隔 离 的 程度 。 隔 离 级 别 从 允许 并 发 负面 影响 (如 脏 读 、 幻 读 等 ) 的 角度 进行 
描述 。SQL Server 2016 支持 的 事务 的 隔离 级 别 从 最 低 到 最 高 有 如 下 4 种 : 

。 未 提交 读 (READ UNCOMMITTED) 。 

。 已 提交 读 (READ COMMITTED) 。 

。 可 重复 读 (REPEATEABLE READ) 。 

。 可 序列 化 (可 串 行 化 .:SERIALIZABLE) 。 

随 着 隔离 级 别 的 提高 ,可 以 更 有 效 地 防止 数据 的 不 一 致 性 。 但 是 ,这 将 降低 事务 的 并 发 
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处 理 能 力 ,会 影响 多 用 户 访问 。 

隔离 级 别 可 以 通过 编程 方式 进行 设置 ,也 可 以 通过 使 用 SQL 请 法 SET TRANSACTION 
ISOLATION LEVEL 进行 设置 。 

(3) 并 发 控制 可 能 产生 的 影响 是 什么 ? 分 别 描述 产生 的 原因 。 

【 答 】 多 个 用 户 访问 同一 个 数据 资源 时 可 能 出 现 并 发 问题 ,其 产生 的 原因 包括 如 下 
4 个 方面 : 

更 新 丢失 。 当 两 个 或 多 个 事务 选择 同一 行 , 然 后 根据 最 初 选 定 的 值 更 新 该 行 时 就 会 
出 现 更 新 丢失 的 问题 。 每 个 事务 都 不 知道 其 他 事务 的 存在 ,最 后 的 更 新 将 覆盖 其 他 事务 所 
做 的 更 新 ,从 而 导致 数据 丢失 。 

@ 不 可 重复 读 。 当 一 个 事务 多 次 访问 同一 行 且 每 次 读 取 不 同 数据 时 会 出 现 不 可 重复 
读 问 题 。 因 为 其 他 事务 可 能 正在 更 新 该 事务 正在 读 取 的 数据 。 

@g) 幻 读 。 当 对 某 行 执行 插入 或 删除 操作 ,而 该 行 属于 某 事 务 正 在 读 取 的 行 的 范围 时 就 
会 出 现 幻 读 问 题 。 

@ 脏 读 。 即 读 出 的 是 不 正确 的 临时 数据 。 例 如 , 当 第 二 个 事务 选择 第 一 个 事务 正在 更 
新 的 行 时 就 会 出 现 此 问题 。 第 二 个 事务 正在 读 取 的 数据 尚未 被 其 他 事务 提交 ,并 可 能 由 更 
新 此 行 的 事务 更 改 。 

(4) 如 何在 事务 中 设置 保存 点 ? 保存 点 有 什么 用 途 ? 

【 答 】 在 事务 中 保存 点 一 般 利用 SAVE TRANSACTION 命令 进行 设置 。 设 置 保存 点 
可 以 不 用 回 深 到 事务 的 起 始 位 置 ,而 是 回 深 到 标记 所 在 的 位 置 即 保 存 点 ,以 提高 事务 执行 的 
效率 。 

(5) 什么 是 死 锁 ? 哪些 方法 可 以 解除 死 锁 ? 

【 答 】 死 锁 是 指 事务 永远 不 会 释放 它们 所 占用 的 资源 , 死 锁 中 的 两 个 事务 都 将 无 限期 

SQL Server 2016 的 SQL Server Database Engine 能 够 自动 检测 死 锁 循环 ,并 选择 一 个 
会 话 作为 死 锁 中 放弃 的 一 方 , 通 过 终止 该 事务 来 打 断 死 锁 。 被 终止 的 事务 发 生 回 滚 ,并 返回 
给 连接 一 个 错误 消息 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进行 操作 ) 

(1) 创建 在 score 表 上 执行 UPDATE 语句 的 事务 UP_score 并 执行 。 

【 答 】 程序 代码 如 下 。 

BEGIN TRAN 

UPDATE dbo. score 
SET daily= 77, final = 88 
WHERE studentno = '18241133077' AND courseno = 'c05109 


COMMIT TRAN 
GO 


将 代码 输入 到 查询 设计 器 中 , 单 击 * 执 行 ?按钮 即 可 执行 事务 UP_score。 

(2) 练习 使 用 ROLLBACK TRANSACTION 语句 回 滚 事 务 并 查看 。 

【 答 】 对 course 表 创 建 插入 行 的 事务 ,向 course 表 中 插入 数据 ,设置 检查 点 。 再 删除 
该 插入 行 , 然 后 回 滚 到 检查 点 。 查 看 course 表 即 可 发 现 插入 数据 行 并 没有 删除 。 


程序 代码 如 下 : 


BEGIN TRAN 
INSERT INTO course 
VALUES( 'c05133', ' 国 际 贸易 ', ' 必 修 ', 32, 2.0); 
SAVE TRAN savel; 
DELETE FROM course 
WHERE courseno = 'c05137'; 
ROLLBACK TRAN savel; 
COMMIT TRAN 
GO 


(3) 练习 在 student 表 上 创建 谋 套 事务 ,分 别 在 内 层 和 外 层 设置 回 深 点 ,检测 回 深 对 表 
数据 的 影响 。 

【 答 】 分 别 在 内 层 事 务 和 外 层 事务 中 设置 回 深 点 savel 和 save2 ,内 层 事务 数据 更 新 后 
进行 提交 ,再 更 新 同一 行 数据 , 回 深 到 savel 。 可 以 通过 浏览 数据 观察 到 内 层 更 新 被 回 滚 。 
程序 代码 如 下 : 


BEGIN TRAN TRAN1 
SAVE TRAN savel; 
BEGIN TRAN TRAN2 
UPDATE student 
SET sname = ' 赵 平 茵 ', point = 997, phone = '053179372727， 
WHERE studentno = '18282613677'; 
SELECT * FROM student WHERE studentno = '18282613677'; 
SAVE TRAN save2; 
COMMIT TRAN TRAN2; 
UPDATE student 
SET sname = ' 孙 释 远 ', point = 987, phone = '053179372727' 
WHERE studentno = '18282613677'; 
ROLLBACK TRAN savel; 
COMMIT TRAN TRAN1; 
SELECT * FROM student WHERE studentno = '18282613677 
GO 


(4) 练习 在 student 表 上 创建 谋 套 事务 ,并 利用 系统 变量 @@TRANCOUNT 编程 , 检 
测 嵌 套 事务 的 执行 情况 。 

【 答 】 利用 @@TRANCOUNT 的 输出 值 , 可 以 观察 到 嵌 套 事务 在 外 层 . 内 层 和 提交 之 
后 的 执行 情况 。 程 序 代码 如 下 ， 


BEGIN TRAN TR1 
PRINT '1st BEGIN TRAN: @@TRANCOUNT=" 
+ CAST(@(@TRANCOUNT AS NVARCHAR(10)); 
SAVE TRAN savel; 
BEGIN TRAN TR2 
PRINT '2nd BEGIN TRAN: @(@TRANCOUNT = ， 
+ CAST(@@TRANCOUNT RS NVARCHAR(10)); 
UPDATE student 
SET sname = ' 赵 平 菌 ', point = 997, phone = '053179372727， 
WHERE studentno = '18282613677'; 
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COMMIT TRAN TR2; 
PRINT '1st COMMIT TRAN: @(@TRANCOUNT =" 
+ CAST(@(@TRANCOUNT RS NVARCHAR(10)); 
ROLLBACK TRAN savel; 
PRINT 'ROLLBACK TRAN: @(@TRANCOUNT=" 
+ CAST(@@TRANCOUNT RS NVARCHAR(10)); 
COMMIT TRAN TR1; 
PRINT 'AFTER COMMIT TRAN TR1: @@TRANCOUNT=" 
+ CRST(@@TRRNCOUNT AS NVARCHAR(10)); 
SELECT * FROM student WHERE studentno = '18282613677'; 
G0 


(5) 练习 在 student 表 上 进行 查询 、 插 和 人 和 更 新 ,然后 使 用 sys. dm_tran_locks 视图 查看 
锁 的 信息 。 

【 答 】 具体 步骤 和 代码 如 下 。 

@ 启动 SQL Server Management Studio 并 创建 一 个 查询 设计 器 窗口 。 

@ 输入 并 执行 下 列 语句 ,对 student 表 进 行 查 询 .插入 和 更 新 。 


BEGIN TRAN 
SELECT studentno, sname 
FROM student 
WHERE studentno = '18282613677'; 
INSERT INTO student 
VALUES( '18282610019', ' 孙 释 远 ', ' 女 ', '1999 -09 一 09', 
'180512',777, '1328909876', 'sdqd@163. com'); 
UPDATE student 
SET sname = ' 孙 释 嘉 ' 
WHERE studentno = '18282613677'; 


@ 利用 动态 管理 视图 sys. dm_tran_locks 查看 事务 中 使 用 的 锁 的 信息 。 在 查询 设计 器 
中 输入 并 执行 以 下 SELECT 语句 来 获取 锁 信息 并 提交 事务 。 
SELECT resource type, resource associated entity id, 
request_status, request mode, request session id, 
resource_description 


FROM sys. dm_tran locks 
WHERE resource_database_id= DB_ID( ‘teaching'); 


@ 提交 事务 。 


COMMIT TRAN 
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1. 选择 题 
(1) SQL Server 2016 默认 的 用 户 登 录 账号 是 

A. BUILTIN\Administrators B. guest 

C. dbo D. sa 
(2) 下 列 命令 用 于 撤销 SQL Server 用 户 对 象 权限 。 

A. REVOKE B. GRANT C. DENY D. CREATE 
(3) SQL Server 2016 中 没有 成 员 是 角色 。 

A. 标准 B. 固定 数据 库 C. 应 用 程序 D. 服务 器 
(4) SQL Server 2016 中 的 主体 对 安全 对 象 的 权限 层次 

A. 不 分 层 B. 分 3 层 C. 分 2 层 D. 分 4 层 
(5) SQL Server 数据 库 用 户 不 能 够 创建 

A. 数据 库 角色 B. 登录 名 

C. 服务 器 角色 D. 应 用 程序 角色 
答案 : DACBC 
2. 思考 题 


(1) 简 述 在 对 象 上 进行 权限 设置 时 ,角色 权限 和 用 户 权 限 的 关系 。 

【 答 】 对 象 权限 表示 对 特定 的 数据 库 对 象 ( 表 、 视 图 、 字 段 和 存储 过 程 ) 的 操作 权限 , 它 
决定 了 能 对 表 、 视 图 等 数据 库 对 象 执行 的 操作 。 在 对 象 上 进行 权限 设置 时 ,可 以 通过 设置 角 
色 权 限 为 一 批 用 户 设置 权限 ,用户 可 以 作为 角色 成 员 继承 其 所 在 角色 的 权限 。 用 户 也 可 以 
单独 设置 权限 ,但 需要 防止 权限 设置 冲突 。 

用 户 可 以 从 一 个 角色 中 接受 一 些 权限 ,而 从 其 他 一 些 角色 中 接受 另 一 些 权 限 。 或 者 用 
户 可 以 拒绝 将 角色 中 的 其 他 成 员 所 具有 的 权限 授予 某 个 用 户 。 

(2) 试 述 应 用 程序 角色 的 建立 方法 和 用 途 。 

【 答 】 建立 应 用 程序 角色 一 般 采 用 如 下 方法 。 

@ 利用 SQL Server Management Studio 创建 应 用 程序 角色 。 

在 “对 象 资源 管理 器 ?下 展开 数据 库 teaching, 右 击 “ 安 全 性 ”下 的 “角色 ”节点 ,在 弹出 的 
快捷 菜单 中 选择 “新 建 ”>“ 应 用 程序 角色 ”命令 。 然 后 在 弹出 的 “应 用 程序 角色 -新 建 ” 对 话 
框 的 “常规 ”选项 卡 中 输入 角色 名 称 、 默 认 架 构 和 密码 等 参数 , 单 击 “ 确 定 ” 按 钮 ,应 用 程序 角 
色 建 成 。 

@ 使 用 系统 过 程 sp_addapprole 创建 应 用 程序 角色 。 

@ 利用 CREATE APPLICATION ROLE 命令 创建 应 用 程序 角色 。 
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应 用 程序 角色 的 用 途 如 下 : 

@ 应 用 程序 角色 可 以 加 强 对 某 一 个 特别 的 应 用 程序 的 安全 性 。 例 如 , 某 层 次 的 公司 职 
员 可 以 用 某 个 特定 的 应 用 程序 来 修改 员工 数据 信息 ,那么 就 可 以 为 其 建立 应 用 程序 角色 。 

@ 创建 应 用 程序 角色 的 目的 是 防止 用 户 直接 访问 底层 表 数 据 。 当 应 用 程序 角色 被 应 
用 程序 的 会 话 激活 以 后 ,会 话 就 会 失去 所 有 属于 登录 ,用户 账号 或 角色 的 权限 ,因为 这 些 角 
色 都 只 适用 于 它们 所 在 的 数据 库 内 部 。 

(3) 简 述 SQL Server 2016 的 登录 名 与 数据 库 用 户 的 关系 。 

【 答 】 在 服务 器 中 的 账户 又 叫 登录 名 ,服务 器 的 登录 名 可 以 映射 到 数据 库 中 成 为 数据 
库 用 户 。 一 个 登录 名 可 以 映射 多 个 数据 库 用 户 ,而 一 个 用 户 只 能 对 应 一 个 登录 名 。 

(4) 简 述 什么 是 数据 库 固定 角色 。 

【 答 】 数据 库 角 色 是 对 数据 库 对 象 操作 权限 的 集合 ,分 为 固定 数据 库 角色 和 用 户 自 定 
义 数 据 库 角色 。 固 定数 据 库 角色 是 由 SQL Server 2016 系统 定义 的 ,可 以 管理 数据 库 作 用 
域 的 可 保护 对 象 。 

对 于 某 个 数据 库 而 言 ,每 一 个 固定 数据 库 角 色 都 有 它 特 定 的 许可 权限 , 即 固定 数据 库 角 
色 的 成 员 的 许可 对 于 某 个 数据 库 是 有 限 的 。 可 以 用 系统 过 程 sp_dbfixdrolepermission 查看 
每 一 个 固定 数据 库 角色 的 许可 。 

(5) 简 述 在 对 象 上 进行 权限 设置 时 ,授予 .拒绝 和 撤销 的 关系 。 

【 答 】 在 对 象 上 进行 权限 设置 时 ,授予 权限 将 删除 所 授予 级 别 上 的 已 拒绝 权限 或 撤销 
权限 ,而 在 另 一 级 别 上 所 拒绝 的 同一 权限 仍然 有 效 。 在 另 一 级 别 上 所 撤销 的 同一 权限 仍然 
适用 ,但 它 并 不 阻止 用 户 访问 该 对 象 。 

撤销 权限 只 删除 所 撤销 级 别 ( 如 包含 该 用 户 、 组 或 角色 ) 上 已 经 授予 的 权限 或 已 经 拒绝 
的 权限 ,而 在 另 一 层次 上 所 授予 或 拒绝 的 主体 的 同一 权限 仍然 有 效 。 

在 SQL Server 2016 中 ,除了 表 级 的 拒绝 权限 并 不 优先 于 列 级 授予 权限 外 ,拒绝 权限 具 
有 各 层次 的 优先 权 ,在 任何 级 别 上 的 拒绝 权限 都 拒绝 该 对 象 的 权限 ,无 论 该 用 户 现 有 的 权限 
是 已 经 授予 还 是 废止 。 

SQL Server 总 是 首先 处 理 被 拒绝 的 权限 , 若 对 public 角色 设置 拒绝 权限 , 则 将 禁止 任 
何 用 户 访问 对 象 。 

3. 上 机 练习 题 (本 题 利 用 teaching 数据 库 进 行 操 作 ) 

(1) 利用 两 种 方法 创建 一 个 SQL Server 登录 名 USER1 ,密码 为 Abc!@ #213。 

【 答 】 Q@ 利用 SQL Server Management Studio 创建 登录 名 。 

在 “对 象 资源 管理 器 "下 右 击 * 安 全 性 ?下 的 “登录 名 ?节点 ,在 弹出 的 快捷 菜单 中 选择 “新 
建 登录 名 ”命令 。 在 “登录 名 -新 建 ” 界 面 上 设置 登录 名 USER1 身份 验证 模式 为 SQL Server 
身份 验证 、 密 码 为 Abc!@ #213、 默 认 数 据 库 (teaching) 和 语言 的 类 型 等 参数 后 . 单 击 “ 确 定 ” 
按钮 即 可 完成 登录 名 的 创建 。 

@) 利用 Transact-SQL 语句 命令 创建 登录 名 。 

程序 代码 如 下 : 

USE master 


GO 
CREATE LOGIN USER1 WITH PASSWORD = 'Abc! @#213' 


(2) 练习 利用 登录 名 USER1 连接 服务 器 。 

【 答 】 在 SQL Server Management Studio 中 使 用 登录 名 USER1 连接 服务 器 。 

OO 右 击 SQL Server Management Studio 中 的 实例 ,在 弹出 的 快捷 菜单 中 选择 “ 连 
接 ” 命 令 。 

@ 在 弹出 的 “连接 服务 器 ”界面 中 选择 SQL Server 身份 验证 ,然后 输入 登录 名 USER1 
和 密码 Abc!1@ #213。 

@ 单 击 “连接 ?按钮 可 以 测试 连接 是 否 成 功 。 若 不 成 功 ,会 出 现 错误 信息 提示 框 。 

@ 若 测 试 成 功 , 则 会 在 “对 象 资源 管理 器 ”中 出 现 连接 成 功 的 信息 。 

(3) 练习 在 teaching 数据 库 中 为 SQL Server 登录 名 USER1 添加 数据 库 用 户 ,并 取 名 
为 USER2 ,默认 架构 为 TEAC。 

【 答 】 程序 代码 如 下 。 

CREATE USER USER2 FOR LOGIN USER1 

WITH DEFAULT_SCHEMA = TEAC 

GO 

(4) 练习 为 teaching 数据 库 新 创建 一 个 数据 库 用 户 USER2 ,并 为 其 赋予 查询 student 
表 的 权限 。 

【 答 】 实现 本 题 要 求 的 操作 步骤 如 下 。 

@ 在 SQL Server Management Studio 中 展开 SQL Server 服务 器 组 中 的 相应 服务 器 。 

@ 创建 一 个 新 的 登录 账户 USER2 ,再 展开 teaching 数据 库 ,在 teaching 数据 库 中 创建 
一 个 新 的 数据 库 用 户 USER2。 

@ 右 击 新 创建 的 数据 库 用 户 USER2, 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ,打开 “ 数 
据 库 用 户 - USER2” 对 话 框 ,在 属性 对 话 框 中 选择 “安全 对 象 ”选择 卡 。 

@ 单 击 “ 添 加 ”按钮 ,打开 “添加 对 象 ” 对 话 框 。 在 “添加 对 象 ” 对 话 框 中 单 击 “ 特 定 对 
象 ”, 并 单 击 “ 确 定 ” 按 钮 ,打开 “选择 对 象 " 对 话 框 。 

@ 在 “选择 对 象 ” 对 话 框 中 单 击 “ 对 象 类 型 ", 打 开 “ 选 择 对 象 类 型 "对 话 框 。 

@ 在 “选择 对 象 类 型 "对 话 框 中 选中 “ 表 ”, 并 单 击 “ 确 定 ” 按 钮 。 在 “选择 对 象 " 对 话 框 中 
单 击 “浏览 ?按钮 ,会 打开 “查找 对 象 " 对 话 框 。 

@ 在 “查找 对 象 " 对 话 框 中 选中 "student 数据 表 ” 复 选 框 ,并 单 击 两 次 “确定 ”按钮 ,返回 
数据 库 用 户 属性 窗口 。 

在 选择 结果 对 话 框 中 选中 SELECT 权限 对 应 的 “授予 ” 复 选 框 ,并 单 击 “ 确 定 ” 按 钮 ， 
即 完成 了 此 题 的 要 求 。 

(5) 练习 将 teaching 数据 库 中 创建 表 的 权限 授予 用 户 USER2。 

【 答 】 程序 代码 如 下 。 


GRANT CREATE TABLE TO USER2 
GO 
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第 12 章 备份 和 恢复 


1. 选择 题 
(1) 下 面 选项 表示 要 执行 差异 备份 。 

A. Recovery B. Norecovery C. Differential D. Noint 
(2) 下 面 数据 库 中 ， 数据 库 不 允许 进行 备份 操作 。 

A. teaching B. model C. msdb D. tempdb 
(3) 还 原 数 据 库 时 ,首先 要 进行 操作 。 

A. 创建 最 近 事 务 日 志 备份 B. 创建 完整 数据 库 备份 

C. 创建 备份 设备 D. 删除 最 近 事务 日 志 备份 
(4) 创建 数据 库 文件 或 文件 组 备份 时 ,首先 要 进行 操作 。 

A. 创建 事务 日 志 备份 B. 创建 完整 数据 库 备份 

C. 创建 备份 设备 D. 删除 差异 备份 
(5) 下 面 故障 发 生 时 ， 需要 数据 库 管 理 员 进行 手工 操作 恢复 。 

A. 停电 B. 不 小 心 删 除 表 数 据 

C. 死 锁 D. 操作 系统 错误 
答案 : CDABB 
2. 思考 题 


(1) 在 备份 数据 库 的 时 候 ,SQL Server 2016 需 执行 哪些 操作 ? 

【 答 】 使 用 SQL Server Management Studio 和 Transact-SQL 语句 都 可 以 备份 数据 
库 , 包 括 完 整备 份 . 差 异 备份 .事务 日 志 备份 以 及 文件 和 文件 组 备份 。 备 份 方法 步骤 大 同 小 
异 ,只 是 选项 或 命令 参数 有 区 别 。 使 用 SQL Server Management Studio 进行 完整 数据 库 备 
份 的 基本 操作 如 下 : 

@ 在 “对 象 资源 管理 器 ”窗口 里 展开 树 形 目录 ,选择 需要 备份 的 数据 库 。 

@ 右 击 该 数据 库 ,在 弹出 的 快捷 菜单 中 选择 “任务 ”备份 ”命令 。 

@ 在 弹出 的 “备份 数据 库 ” 对 话 框 中 设置 参数 : 

。 选择 要 备份 的 数据 库 ; 

。 选择 要 备份 类 型 ; 

。 设置 “备份 集 ” 的 信息 ; 

。 设置 “备份 集 过 期 时 间 ”; 

。 备份 数据 库 路 径 或 设备 。 


@ 单 击 “确定 ”按钮 即 可 完成 完整 数据 库 备份 。 

(2) 什么 是 差异 备份 ? 什么 情况 下 适合 使 用 差异 备份 ? 

【 答 】 差异 备份 用 于 存储 在 上 一 次 备份 之 后 发 生 改 变 的 数据 。 当 一 些 数 据 在 上 一 次 完 
整备 份 后 被 改变 多 次 的 时 候 ,差异 备份 只 存储 更 改 数 据 的 最 新 版 本 。 

差异 备份 适合 完整 备份 已 经 存在 , 且 数 据 库 中 的 数据 库 变 化 较 快 的 情况 下 进行 。 

(3) 制订 备份 计划 时 应 该 考虑 哪些 因素 ? 

【 答 】 制订 一 个 可 行 的 备份 计划 ,应 当 考 虑 备份 的 内 容 、 备 份 存储 的 位 置 .备份 的 频率 、 
备份 的 介质 等 。 

(4) 进行 数据 库 还 原 应 该 注意 哪些 问题 ? 

【 答 】 在 还 原 数据 库 的 时 候 应 该 注意 如 下 问题 。 

@ 了 解 执行 的 备份 方法 的 类 型 和 备份 是 否 存在 。 

@ 确认 备份 文件 包含 要 还 原 的 备份 ,并 确认 备份 是 否 有 效 , 且 包含 完整 的 备份 集 。 

@ 如 果 使 用 完整 数据 库 备 份 来 还 原 数据 库 ,SQL Server 2016 重新 创建 这 些 数据 库 文 
件 和 所 有 的 数据 库 对 象 。 如 果 使 用 差异 数据 库 备 份 来 恢复 , 则 可 以 恢复 最 近 的 差异 数据 库 
备份 。 

@ 在 数据 库 还 原 过 程 中 确保 要 还 原 的 数据 库 没 有 打开 的 连接 。 因 为 在 进行 还 原 的 时 
候 不 允许 有 连接 到 数据 库 的 连接 。 

@ 数据 库 还 原 前 , 先 要 进行 活动 事务 日 志 备份 ,以 免 丢 失信 息 。 

(5) 发 生 介质 故障 的 原因 主要 有 哪些 ? 如 何 处 理 ? 

【 答 】 一 般 来 说 ,应 该 在 问题 发 生 之 前 不 断 地 监视 数据 库 , 使 用 数据 库 一 致 性 检查 语句 
来 监视 数据 库 的 一 臻 性。 如果 由 于 物理 介质 发 生 读 写 错误 ,或 者 管理 员 在 操作 过 程 中 不 慎 
删除 一 些 重 要 数据 或 日 志文 件 ,会 产生 介质 故障 。 

介质 故障 需要 数据 库 管理 员 手 工 进行 恢复 ,恢复 时 需要 在 发 生 故障 前 的 数据 库 备份 和 
日 志 备 份 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 进行 操作 ) 

(1) 练习 对 数据 库 teaching 创建 完整 数据 库 备份 和 差异 备份 。 

【 答 】 对 数据 库 teaching 创建 完整 数据 库 备 份 的 程序 代码 如 下 。 


BACKUP DATABASE teaching 

TO DISK = N'D:\DATA\backteaching’ 

WITH EXPIREDATE = N'06/06/2020 00:00:00… 
NAME = N'teaching -完整 数据 库 备份 '， 

STATS = 10 

GO 


对 数据 库 teaching 创建 差异 备份 的 程序 代码 如 下 : 


BACKUP DATABASE teaching 

TO DISK = N'D:\DATA\backteaching' 

WITH DIFFERENTIAL , 

EXPIREDATE = N'17/06/2017 00:00:00', 
NOFORMAT, NOINIT, 

NAME = N'teaching -差异 数据 库 备份 '， 
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SKIP, NOREWIND, NOUNLOAD, STATS = 10 
GO 
declare @backupSetId as int 
select @backupSetId = position 
from msdb. . backupset 
where database name = N'teaching'and backup_set_id = 
(select max(backup_set_id) 
from msdb. . backupset 
where database_name = N'teaching' ) 
证 @backupSetId is null 
begin 
raiserror(N' 验 证 失败 . 找 不 到 数据 库 "teaching" 的 备份 信息 .',，16, 1) 
end 
RESTORE VERIFYONLY 
FROM DISK = N'D:\DATA\backteaching' 
WITH FILE = @backupSetId, NOUNLOAD, NOREWIND 
GO 


(2) 练习 通过 上 述 完整 数据 库 备份 和 差异 备份 对 数据 库 teaching 进行 恢复 。 
【 答 】 对 数据 库 teaching 进行 恢复 的 程序 代码 如 下 。 


RESTORE DATABASE teaching 

FROM DISK = N'D:\DATAbackteaching' 
WITH FILE = 2, NORECOVERY, NOUNLOAD, 
STATS = 10 

GO 

RESTORE DATABASE teaching 

FROM DISK = N'D:\DATA\backteaching' 
WITH FILE = 3, NOUNLOAD, 
STATS = 10 

GO 


(3) 练习 为 SQL Server 2016 系统 事务 日 志 创建 备份 设备 ,并 备份 teaching 数据 库 的 事 
务 日 志 。 
【 答 】 创建 备份 设备 的 程序 代码 如 下 。 


USE master 

GO 

EXEC master. dbo. sp_addumpdevice 

@devtype = N'disk', 

@logicalname = N'devicel', 

@physicalname = N'D:\DATA\back devicel. bak' 
GO 


备份 teaching 数据 库 的 事务 日 志 的 程序 代码 如 下 。 


BACKUP LOG teaching 

TO devicel 

WITH RETAINDAYS = 3, NOFORMAT, NOINIT, 
NAME = N'teaching 一 事务 日 志 备 份 '， 
SKIP, NOREWIND, NOUNLOAD, 


STATS = 10 
GO 


(4) 如 果 有 一 个 大 小 为 1024GB 的 数据 库 , 数 据 库 中 的 表 存 储 于 一 个 单独 的 文件 组 。 
车 要 备份 整个 数据 库 , 需 要 22 个 小 时 ,如 何 才能 最 小 化 每 天 执行 备份 的 时 间 ,并 能 够 保证 良 
好 的 数据 恢复 能 力 ? 

【 答 】 一 般 来 说 ,数据 库 中 的 数据 是 不 断 更 新 的 。 为 保证 可 以 每 天 执行 备份 的 时 间 最 
小 化 和 良好 的 数据 恢复 能 力 , 可 以 参考 采用 如 下 方法 : 

Qa 在 备份 大 型 数据 库 时 ,可 以 选用 一 种 以 完全 数据 库 备 份 开始 的 备份 计划 。 

@ 将 数据 划分 到 5 个 文件 中 保存 ,以 轮流 方式 每 天 只 备份 数据 库 文件 中 的 一 个 。 

@ 每 天 除了 备份 事务 日 志 以 外 ,用 户 可 以 进行 差异 备份 。 
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1. 选择 题 
(1) 执行 自动 执行 管理 任务 之 前 ,首先 要 对 SQL Server 代理 进行 操作 。 
A. 启动 B. 配置 C. 新 建 D. 更 新 
(2) SQL Server 2016 提供 很 多 服务 工具 ,主要 用 于 自动 执行 管理 任务 的 是 
A. 备份 B. 传输 C. SQL Server 代理 D. 显示 日 志 
(3) 下 面 不 是 在 警报 发 生 时 通知 操作 员 的 方法 。 
A. 电子 邮件 B. 使 用 呼叫 
C. SQL Server 代理 D. 发 送 网 络 消息 
(4) 作业 是 由 一 系列 SQL Server 代理 顺序 执行 的 指定 操作 ,不 可 以 
A. 触发 执行 B. 手工 执行 
C. 调度 执行 D. 触发 警报 执行 
(5) 下 列 自动 化 管理 任务 中 不 是 执行 正常 调度 任务 的 是 
A. 维护 数据 一 致 性 
B. 传输 和 转换 数据 
C. 维护 索引 
D. 因数 据 库 事务 满 了 而 清除 事务 日 志 
答案 : ACCAA 
2. 思考 题 


(1) 事件 .警报 和 作业 的 关系 是 什么 ? 

【 答 】 事件 就 是 由 SQL Server 系统 发 生 的 、 写 人 到 Windows 的 事件 日 志 中 的 错误 或 
消息 。 警 报 是 SQL Server 2016 数据 库 提供 的 一 种 对 事件 等 信息 进行 检测 的 机 制 。 作 业 是 
由 一 系列 SQL Server 代理 顺序 执行 的 指定 操作 ,包括 运行 Transact-SQL 脚本 、 命 令 行 应 用 
程序 和 查询 等 任务 。 作 业 和 警报 都 可 以 单独 定义 和 单独 执行 。 

作业 可 以 由 系统 的 警报 触发 执行 ,警报 负责 回应 Microsoft SQL Server 系统 发 生 的 事 
件 。 警 报 由 事件 触发 ,其 触发 的 结果 既 可 以 是 执行 作业 ,也 可 以 是 通知 操作 员 。 

(2) 如 何 通 过 “作业 活动 监视 器 "管理 作业 活动 的 情况 ? 

【 答 】 通过 “作业 活动 监视 器 ”管理 作业 活动 的 步 又 如 下 。 

@ 展开 SQL Server 代理 , 右 击 “作业 活动 监视 器 ”选项 。 

@ 在 弹出 的 快捷 菜单 中 选择 “查看 作业 活动 ”命令 。 

图 弹出 如 图 13-1 所 示 的 “作业 活动 监视 器 "对话 框 , 可 以 查看 当前 的 作业 活动 
情况 。 


谭 人 活动 监视 占 - LG37CEYPE9YWCSG - 0O x 
下 次 出 新 : 
手动 
国 下 友和 上 次 运行 结果 ”上 次 运行 时 间 下 次 运行 时 间 类 别 i 
祷 先 器 。 无 未 知 从 不 2018/2/27 2:0..。 数据 -， 是 
es 成 功 2018/2/26 18:59:56 。 2018/3/4 0:00:00 。 堵 据 是 
了 二 二 和 8 竺 后 办 2018/2/26 19:57:59 未 计划 球 .. 是 
成 功 2018/2/26 15:12;53 ”2018/2/27 2:0..， [未 - 是 
| 
服务 器 L637CEYFE9YWCSG 成 由 2018/2/26 19:00:11 2018/3/4 0:00:00 数据 ..， 是 
连 摘 ，L637CEYPE9YWCSGWdninistrator 
考查 在 连接 属性 
四 
HU | > 
关闭 (C) 


图 13-1 “作业 活动 监视 器 ”对 话 框 
@ 如 果 单 击 * 筛 选 ?按钮 ,弹出 如 图 13-2 所 示 的 “筛选 设置 ”对 话 框 ,可 以 实现 对 作业 进 
行 筛选 操作 。 
@ 也 可 以 进行 刷新 和 帮助 等 操作 ,最 后 单 击 “关闭 "按钮 。 


2018 年 2 月 ， 
局 一 周二 周三 周 四 周 五 周 六 周 日 
29 30 31 1 多 3 4 
5 6 7 8 91011 
12 13 14 15 16 17 18 
19 20 21 22 23 24 25 
四 27 2 1 2 3 4 
5 6 7 8 9 10 11 
今天 2018/2/26 


13-2 “筛选 设置 ”对话 框 


(3) 如 何 创建 警报 ? SQL Server 支持 哪些 类 型 的 警报 ? 

【 答 】 创建 警报 可 以 采用 SQL Server Enterprise Manager 图 形 方式 或 Transact-SQL 
命令 方式 。 在 SQL Server Enterprise Manager 中 创建 警报 的 参考 步骤 如 下 。 

a 在 “对 象 资源 管理 器 ”中 展开 “SQL Server 代理 ”, 然 后 右 击 “警报 ”选项 ,从 弹出 的 快 | 第 
捷 菜 单 中 选择 “新 建 警报 ”命令 ,将 出 现 “新 建 警报 属性 ”对话 框 。 该 对 话 框 有 三 个 选项 卡 , 即 | 13 
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“常规 “响应 ”和 “选项 ”选项 卡 。 

。“ 常 规 ” 选 项 卡 。 指 定 警 报 的 名 称 、 类 型 .激活 方式 和 所 在 的 数据 库 等 。 

。“ 响 应 ”选项 卡 。 可 以 选择 是 否 执 行 作业 ,执行 哪 一 个 作业 ,是 否 通知 操作 员 、 以 何 种 

方式 通知 操作 员 等 信息 。 

。“ 选 项 ?选项 卡 。 设 置 警报 的 发 送 方式 等 附加 内 容 , 如 电子 邮件 等 。 

@ 设置 完毕 , 单 击 “ 确 定 ” 按 钮 即 可 。 

SQL Server 支持 的 警报 类 型 : 警报 SQL Server 系统 或 用 户 定义 的 已 经 写 人 到 
Windows 应 用 程序 日 志 中 的 错误 或 消息 。 在 SQL Server 系统 中 ,错误 代号 小 于 或 等 于 
50 000 的 错误 或 消息 是 系统 提供 的 错误 使 用 的 代号 ,用 户 定 义 的 错误 代号 必须 大 于 50 000。 
错误 代号 是 触发 警报 最 常 使 用 的 方式 。 错 误 等 级 也 是 错误 是 否 触 发 警报 的 一 种 条 件 ,在 
SQL Server 系统 中 提供 了 25 个 等 级 的 错误 。 在 这 些 错误 等 级 中 ,19 一 25 等 级 的 错误 自动 
写 人 Windows 的 应 用 程序 日 志 中 ,这 些 错误 是 致命 错误 。 

(4) 如 何 创建 作业 ? 作业 可 以 包括 哪些 类 型 的 步骤 ? 

【 答 】 创建 作业 可 以 采用 SQL Server Enterprise Manager 图 形 方式 或 Transact-SQL 
命令 方式 。 在 SQL Server Enterprise Manager 中 创建 作业 的 参考 步骤 如 下 。 

QO 在 “对 象 资源 管理 器 ”中 展开 *SQL Server 代理 ”, 然 后 右 击 “作业 ”选项 ,在 弹出 的 快 
捷 菜 单 中 选择 “新 建 作业 "命令, 出现“ 新建 作业 ”对 话 框 。 该 对 话 框 有 “常规 ”“ 步 又 ”等 6 个 
选项 卡 。 

。“ 常 规 ” 选 项 卡 。 可 以 输入 该 作业 的 名 称 、 所 有 者 、 类 别 以 及 说 明 等 信息 。 
“步骤 ”选项 卡 。 单 击 “ 新 建 "按钮 会 出 现 “ 新 建 作业 步骤 ”对 话 框 ,在 该 对 话 框 中 有 
“常规 ”和 “高 级 ”两 个 选项 卡 。 可 以 在 该 对 话 框 中 定义 作业 步骤 的 详细 信息 。 
“新 建 作业 步骤 "对话 框 中 的 “常规 ?选项 卡 。 该 选项 卡 用 于 输入 作业 步骤 的 基本 信 
息 ,如 “步骤 名 称 “ 类 型 数据库“ 运行 身份 “命令 ”等 。 
“高 级 ”选项 卡 。 可 以 设置 该 作业 步 又 执行 成 功 或 失败 后 的 行为 、 重 试 次 数 、 存 放 结 
果 文 件 的 位 置 、 是 否 覆 盖 结 果 文 件 中 原 有 的 信息 ,以 及 作为 哪 一 个 用 户 账户 运行 等 。 
。“ 计 划 ” 选 项 卡 。 可 以 设置 多 个 计划 ,只 要 满足 其 中 一 个 计划 , 则 该 作业 就 可 以 执行 。 
“警报 ?选项 卡 。 用 于 管理 警报 。 

。“ 通 知 ” 选 项 卡 。 在 该 选项 卡 中 可 以 设置 当 该 作业 完成 时 系统 可 以 采取 的 动作 ,这 些 

动作 包括 使 用 电子 邮件 、 使 用 呼叫 、 使 用 网 络 消息 等 方式 通知 操作 员 。 

@ 设置 完成 , 单 击 * 确 定 "按钮 即 可 。 

(5) 简 述 手动 创建 维护 计划 的 步骤 。 

【 答 】 手动 创建 维护 计划 的 参考 步骤 如 下 。 

Oa 在 “对 象 资源 管理 器 ”中 展开 SQL Server 实例 的 “管理 ”文件 夹 , 然 后 右 击 “ 维 护 计 
划 ” 文 件 夹 , 在 弹出 的 快捷 菜单 中 选择 “新 建 维护 计划 ”命令 。 

@ 在 弹出 的 “新 建 维 护 计 划 ” 对 话 框 中 输入 维护 计划 名 称 , 单 击 “ 确 定 ” 按 钮 。 进 入 设计 
界面 ,选择 “视图 ”一 “工具 箱 ” 命 令 。 

@ 在 设计 界面 的 “说 明 " 后 面 输入 该 计划 的 描述 , 单 击 “ 计 划 ” 后 的 按钮 设置 作业 计划 。 

@ 将 “工具 箱 ” 中 的 任务 流 元 素 拖 到 设计 界面 ,以 便 定义 要 执行 的 任务 ,并 定义 任务 之 
间 工 作 流 的 操作 : 拖 动 连接 线 到 指定 任务 元 素 。 


@ 双击 每 一 个 任务 流 元 素 ,在 打开 的 对 话 框 中 配置 任务 选项 ,如 连接 服务 器 、 选 择 要 操 
作 的 数据 库 等 。 

@ 单 击 “ 连 接 ” 按 钮 ,将 与 创建 该 计划 所 在 的 服务 器 建立 本 地 连接 。 单 击 “ 日 志 记 录 ” 按 
钮 ,可 以 指定 生成 报告 的 路 径 和 文件 名 等 ,并 保存 设置 即 可 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 进行 操作 》) 

(1) 练习 启动 和 停止 SQL Server 2016 服务 代理 。 

【 答 】 启动 SQL Server 2016 服务 代理 的 方法 有 如 下 几 种 。 

g@ 在 “对 象 资源 管理 器 ”中 右 击 “SQL Server 代理 ”选项 ,然后 在 弹出 的 快捷 菜单 中 选 
择 “ 启 动 ” 命 令 即 可 启动 SQL Server 代理 。 

@ 在 “SQL Server 配置 管理 器 ”里 设置 。 在 “SQL Server Agent (MSSQLSERVER) 属 
性 ”对 话 框 中 选择 “服务 ”选项 卡 , 找 到 “启动 模式 ”项 , 单 击 下 三 角 按钮 ,在 下 拉 列 表 框 中 选择 
“自动 ”选项 ,然后 单 击 “ 确 定 ” 按 钮 。 

@@ 在 “服务 "里 设置 启动 SQL Server 代理 。 选 择 “ 开 始 ”>“ 管 理工 具 ” 一 “服务 ”命令 ; 
或 者 选择 “开始 ”一 “ 控 制 面板 ”>“ 服 务 "命令 。 右 击 “SQL Server 代理 ”选项 ,在 弹出 的 快捷 
菜单 中 选择 “属性 ”命令 ,在 弹出 的 “SQL Server Agent(MSSQLSERVER) 的 属性 ”对话 框 中 
设置 “启动 类 型 为 “自动 ”。 

停止 SQL Server 代理 的 方法 : 

按照 启动 的 步骤 ,分 别 选 择 “ 停 止 " 或 “禁用 ” 即 可 完成 停止 SQL Server 代理 的 操作 。 

(2) 练习 创建 一 个 名 为 student 的 作业 ,并 创建 计划 ,使 得 该 作业 每 周 六 上 午 10 : 00 执 
行 一 次 。 
【 答 】 创建 student 作业 ,并 创建 计划 planl 的 程序 代码 如 下 。 
USE msdb 
GO 
DECLARE (@jobId BINARY(16) 
EXEC msdb. dbo. sp_add job @job name= N'student', 

@enabled=1, 

@notify_level_eventlog=0, 

@notify level email =2, 

@notify level netsend=2, 

@notify_level page=2, 

@delete level=0, 

@category_name = N'[Uncategorized (Local)]', 

@owner_login_name = N'LG37CEYPE9YWCSG\Administrator', @job_id = @jobId OUTPUT 
select @jobId 
GO 
EXEC msdb. dbo. sp_add_ jobserver @ job_name = N'student', @server name = N'LG37CEYPE9YWCSG' 
GO 
USE [msdb] 
GO 
EXEC msdb. dbo. sp_add jobstep @ job_name = N'student', @step name= N'student1' 

@step_id=1, 

@cmdexec_success_code= 0, 

@on_success action=1, 

@on fail action=2, 
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@retry attempts= 0, 
@retry_interval = 0, 
@os_run priority= 0, @subsystem = N'TSQL', 
@command = N'BACKUP DATABASE test01 TO DISK = ''D:\sqlprogram\ADVFULLO2.BAK'"', 
@database name= N'test02', 
@flags=0 
GO 
USE [msdb] 
GO 
EXEC msdb. dbo. sp_update job @job name = N'student', 
@enabled=1, 
@start_step_id=1, 
@notify level eventlog=0, 
@notify level email =2, 
@notify level netsend=2, 
@notify level page=2, 
@delete level =0, 
@description = N' 
@category_name = N'[Uncategorized (Local)]', 
@owner _ login name= N'LG37CEYPE9YWCSG\ Administrator', 
@notify email operator name=N'', 
@notify netsend operator name=N'', 
@notify page operator name=N'' 
GO 
USE [msdb] 
GO 
DECLARE @schedule_id int 
EXEC msdb. dbo. sp_add_jobschedule @job name = N'student', @name = N'plan', 
@enabled=1, 
@freq type=8, 
@freq_interval = 64, 
@freq_subday type=1, 
@freq_subday_interval = 0, 
@freq relative_interval = 0, 
@freq_recurrence factor=1, 
@active_start_date = 20180226, 
@active_end_date = 20180226, 
@active_start_time = 100000, 
@active_end time= 235959, @schedule id = @schedule id OUTPUT 
select @schedule_id 
GO 


(3) 创建 警报 alertl , 当 该 警报 发 生 时 ,利用 电子 邮件 通知 操作 员 。 
【 答 】 创建 警报 alertl 的 程序 代码 如 下 。 


USE msdb 

GO 

EXEC msdb. dbo. sp_add alert @name = N'alertl', 
@nessage_id=0, 
@severity= 8, 
@enabled= 1, 


@delay between responses = 30, 
@include event description in=1, 
@notification_message = N' 交 易 时 间 即 将 结束 ,请 及 时 处 理 数据 '， 
@job_id= N'db8abb83 - 8552 - 49b0 - a613 - 0c223a0bbfdd' 
GO 
EXEC msdb. dbo. sp_add_notification @alert_name = N'alertl', 
@operator name= N'operator', @notification method = 1 
GO 


(4) 创建 操作 员 operator, 练 习 为 该 操作 员 分 配 警 报 。 
【 答 】 创建 操作 员 operator 的 程序 代码 如 下 。 


USE msdb 

GO 

EXEC msdb. dbo. sp_add_operator @name = N'operator', 
@enabled=1, 


@weekday_pager_start time= 80000, 
@weekday_pager_end time = 180000, 
@pager_days = 62, 
@email_address = N'abc123@ sina. com' 

GO 

EXEC msdb. dbo. sp_add_notification @alert_name = N'alertl', 
@operator_name = N'operator’, 
@notification method = 1 

GO 

EXEC msdb. dbo. sp_add_notification @alert_name = N'alertl', 
@operator_name = N'operator', 
@notification method = 1 

GO 


(5) 创建 一 个 维护 计划 maintainl ,实现 每 天 对 teaching 数据 库 进 行 一 次 备份 。 
【 答 】 创建 维护 计划 maintainl 的 程序 代码 如 下 。 


USE msdb 

GO 

/xxxxxx Object: Job [maintain1.Subplan 1] Script Date: 2018/2/26 19:21:12 xxxxxx/ 
BEGIN TRANSACTION 

DECLARE @ReturnCode INT 

SELECT @ReturnCode = 0 

/ xxxxx#¥ Object: JobCategory [Database Maintenance] Script Date: 2018/2/26 19:21:12 x# 
xx / 

IF NOT EXISTS (SELECT name FROM msdb. dbo. syscategories WHERE name = N'Database Maintenance' AND 
category class=1) 

BEGIN 

EXEC @ReturnCode = msdb. dbo. sp_add category @class = N'JOB', @type = N'LOCAL', @name = N' 
Database Maintenance' 

IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 


END 

DECLARE (@ jobId BINARY(16) 第 

EXEC @ReturnCode = msdb. dbo. sp_add job @job name= N'maintain]l.Subplan 1" 13 
@enabled=1, 章 
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@notify level eventlog=2, 
@notify level email=0, 
@notify level netsend=0, 
@notify level page=0, 
@delete level=0, 
@description =N' 无 描述 .'， 
@category name = N'Database Maintenance’, 
@owner_login name = N'LG37CEYPE9YWCSG\Administrator', @job_ id = @jobId OUTPUT 
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
/x*¥¥¥¥¥* Object: Step [Subplan 1] Script Date: 2018/2/26 19:21:13 x x xX%%%/ 
EXEC @ReturnCode = msdb. dbo. sp_add_ jobstep @job_id= @jobId, @step name = N'Subplan 1', 
@step_id=1, 
@cmdexec_success_code=0, 
@on_success action=1, 
@on_success_step_id= 0, 
@on fail action=2, 
@on fail step_id=0, 
@retry attempts = 0, 
@retry_interval = 0, 
@os_run priority = 0, @subsystem = N'SSIS', 
@command = N'/Server " $ (ESCAPE_ NONE(SRVR))" /SQL "Maintenance Plans\maintainl" /set "\ 
Package\Subplan 1.Disable;false"', @flags=0 
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
EXEC @ReturnCode = msdb. dbo. sp_update job @job id = @joblId, @start step id = 1 
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
EXEC @ReturnCode = msdb. dbo. sp_add_jobschedule @job_id= @jobId, @name = N'maintainl. 备 
份 数 据 库 ( 完 整 )'， 
@enabled=1, 
@freq type=4, 
@freq_interval =1, 
@freq subday type=1, 
@freq subday interval =0, 
@freq relative interval =0, 
@freq recurrence factor =0, 
@active_start_date = 20180226, 
@active_end date = 99991231, 
@active_start_time = 20000, 
@active_end time = 235959, 
@schedule uid= N'8f38af53 - 6c10 - 4e2b - 97d2 - c98a335b8e6f" 
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
EXEC @ReturnCode = msdb. dbo. sp_add jobserver @job_id = @jobId, @server name = N' 
(local)， 
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
COMMIT TRANSACTION 
GOTO EndSave 
QuitWithRollback: 
IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION 
EndSave: 
GO 


第 14 章 复制 与 性 能 监 


1. 选择 题 
(1) 复制 的 类 型 有 三 种 ,不 包括 5 

A. 快照 复制 B. 事务 复制 C. 复制 向 导 D. 合并 复制 
(2) 如 果 发 布 服务 器 有 大 量 插入 更 新 和 删除 数据 的 操作 ,适合 采用 

A. 快照 复制 B. 事务 复制 C. 复制 向 导 D. 合并 复制 
(3) 如 果 数 据 库 内 很 少 更改 数 据 ,适合 采用 E 

A. 快照 复制 B. 事务 复制 C. 文件 复制 D. 合并 复制 
(4) 监视 SQL Server 的 性 能 对 象 时 ,通常 不 关注 

A. 磁盘 读 写 B. CPU 使 用 率 C. 内 存 用 量 D. 打印 速度 
(5) 用 户 可 以 利用 系统 性 能 监视 器 创建 监视 数据 库 实 例 。 

A. 函数 B. 网 络 信息 C. 计时 器 D. 图 表 
答案 : CBADD 
2. 思考 题 


(1) 简 述 SQL Server Profiler 的 主要 功能 。 

【 答 】 SQL Server Profiler 是 一 个 功能 丰富 的 界面 ,用 于 创建 和 管理 跟踪 ,并 分 析 和 重 
播 跟踪 结果 。SQL Server Profiler 的 主要 功能 如 下 。 

@ 监视 SQL Server 数据 库 引 擎 分析 服务 器 或 Integration Services 的 实例 性 能 。 

@ 调试 Transact-SQL 语句 和 存储 过 程 。 在 项 目 开发 阶段 ,通过 单 步 执行 语句 来 测试 
Transact-SQL 语句 和 存储 过 程 ,以 确保 代码 按 预 期 方式 运行 。 

@ 通过 标识 低速 执行 的 查询 来 分 析 性 能 ,保存 显示 计划 的 结果 来 执行 查询 分 析 。 将 性 
能 计数 器 与 跟踪 关联 以 诊断 性 能 问题 。 

@ 通过 重播 跟踪 来 执行 负载 测试 和 质量 保证 。 实 现 重播 一 个 或 多 个 用 户 的 跟踪 。 

@ 通过 捕获 生产 系统 中 的 事件 并 在 测试 系统 中 重播 这 些 事件 来 解决 SQL Server 中 的 
问题 。 这 对 测试 和 调试 很 有 用 ,并 使 得 用 户 可 以 不 受 干 扰 地 继续 使 用 生产 系统 。 

@ 审核 和 检查 在 SQL Server 实例 中 发 生 的 活动 。 这 使 得 安全 管理 员 可 以 检查 任何 审 
核 事件 ,包括 登录 尝试 的 成 功 与 失败 ,以 及 访问 语句 和 对 象 权限 的 成 功 与 失败 。 

@ 聚合 跟踪 结果 以 允许 对 相似 事件 类 进行 分 组 和 分 析 。 人 允许 非 管理 员 用 户 创建 跟踪 ， 
配置 可 用 于 以 后 跟踪 的 跟踪 模板 。 

对 SQL Server Profiler 的 使 用 取决 于 何 种 目的 监视 SQL Server Database Engine 实 
例 。 例 如 ,在 生产 周期 的 开发 阶段 则 会 更 关心 如 何 尽 可 能 地 获取 所 有 的 性 能 详细 信息 ,而 不 
会 过 于 关心 跟踪 多 个 事件 会 造成 多 大 的 开销 。 相 反 , 若 正在 监视 生产 服务 器 , 则 会 希望 跟踪 
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更 加 集中 ,并 尽 可 能 占用 较 少 的 时 间 ,以 便 尽 可 能 地 减轻 服务 器 的 跟踪 负载 。 

(2) 简 述 对 一 个 数据 库 创 建 发 布 和 订阅 的 主要 步骤 。 

【 答 】 对 一 个 数据 库 创建 发 布 的 主要 步骤 如 下 。 

@ 在 Microsoft SQL Server Management Studio 中 连接 到 发 布 服务 器 ,在 “对 象 资源 管 
理 器 ”中 展开 “复制 "文件 夹 ,再 右 击 “本 地 发 布 ” 文 件 夹 。 

@ 在 弹出 的 快捷 菜单 中 选择 “新 建 发 布 " 命 令 , 弹 出 “新 建 发 布 向 导 ” 对 话 框 ,选择 发 布 
数据 库 。 

@ 选择 发 布 类 型 。 用 户 可 以 选择 能 够 较 好 的 支持 应 用 程序 要 求 的 发 布 类 型 ,以 及 要 发 
布 的 对 象 。 如 在 “项 目 ” 对 话 框 中 选择 表 等 。 

@ 在 “筛选 表 行 ?对 话 框 中 可 以 单 击 * 添 加 ”按钮 ,根据 需要 进行 表 中 数据 行 的 选择 ,本 
例 选择 所 有 行 。 

@ 配置 “快照 代理 ”。 用 户 可 以 设置 代理 的 安全 性 。 在 创建 复制 的 过 程 中 ,向 导 会 建立 
一 系列 的 SQL Server 代理 作业 ,以 帮助 完成 复制 的 实现 与 维护 工作 。 可 以 单 击 “ 安 全 设 
置 ”, 在 弹出 的 “快照 代理 安全 性 ”对 话 框 中 指定 SQL Server 代理 账户 ,设置 完成 后 单 击 “ 确 
定 ” 按 钮 ,返回 “代理 安全 性 ”对 话 框 。 

@ 设置 “向 导 操 作 ” 对 话 框 ,如 本 例 选择 默认 项 “在 向 导 结 束 时 一 创建 发 布 ”。 

@ 在 “完成 该 向 导 ” 对 话 框 中 通过 提示 信息 对 前 面 的 选择 进行 回顾 ,确认 后 单 击 “ 完 成 ” 
按钮 ,开始 创建 发 布 。 系 统 显 示 “ 正 在 创建 发 布 ”的 信息 ,全 部 显示 成 功 后 单 击 “ 关 闭 ” 按 钮 ， 
完成 创建 发 布 。 在 “对 象 资源 管理 器 ”中 可 以 查看 新 建 的 发 布 。 

对 一 个 数据 库 创建 订阅 的 主要 步骤 如 下 。 

@ 在 SQL Server Management Studio 中 的 命名 实例 中 展开 “复制 "节点 ,然后 右 击 
“本 地 订阅 "节点 ,在 弹出 的 快捷 菜单 中 选择 “新 建 订阅 "命令 ,弹出 “新 建 订阅 向 导 ” 对 
话 框 。 

@ 在 “新 建 订阅 向 导 ” 的 “发 布 " 对 话 框 中 ,从 “发 布 服务 器 ”下 拉 列 表 框 中 选择 “< 查找 
SQL Server 发 布 服务 器 >”。 在 “连接 到 服务 器 ”对 话 框 中 连接 到 发 布 服务 器 (默认 实例 ) , 然 
后 在 "发布" 页 上 选择 一 个 发 布 。 

@ 在 “分 发 代理 位 置 ” 对 话 框 中 选择 分 发 代理 位 置 。 在 “订阅 服务 器 ”对 话 框 中 选择 “新 
建 数据 库 ” ,创建 目 标 数 据 库 。 

@ 在 “分 发 代理 安全 性 ”对 话 框 中 设置 分 发 代理 安全 性 选项 后 , 单 击 “ 确 定 ” 按 钮 。 在 
“同步 计划 ”对 话 框 中 指定 每 个 订阅 的 代理 的 同步 计划 。 在 “初始 化 订阅 ”对 话 框 中 用 户 可 以 
指定 “立即 ”的 初始 化 选择 。 

@ 设置 “向 导 操 作 ” 对 话 框 ,本 例 选 择 默 认 项 “在 向 导 结束 时 一 创建 订阅 ”。 

@ 在 “设置 脚本 文件 属性 ”对 话 框 中 设置 脚本 文件 存放 位 置 等 。 

@ 在 “完成 该 向 导 ” 对 话 框 中 通过 提示 信息 对 前 面 的 选择 进行 回顾 ,确认 后 单 击 “ 完 成 ” 
按钮 ,订阅 开始 创建 。 

创建 订阅 后 ,用 户 可 以 在 “资源 管理 器 ”窗口 中 查看 发 布 和 订阅 。 此 时 用 户 可 以 在 发 
布 数据 库 中 向 数据 库 的 表 中 插入 数据 ,在 订阅 数据 库 的 表 中 看 到 同步 的 结果 。 

(3) 简 述 复制 的 类 型 及 各 类 型 的 作用 。 

【 答 】 复制 的 三 种 类 型 是 事务 复制 、 合 并 复制 和 快照 复制 。 三 种 复制 的 主要 作用 如 下 。 


Q@ 事务 复制 通常 用 于 服务 器 到 服务 器 环境 中 。 事 务 复制 主要 用 于 以 下 情况 : 

。 和 希望 发 生 增 量 更 改 时 将 其 传播 到 订阅 服务 器 。 

。 从 发 布 服务 器 上 发 生 更 改 到 更 改 到 达 订 阅 服务 器 ,应 用 程序 需要 这 两 者 之 间 的 滞后 
时 间 较 短 。 应 用 程序 需要 访问 中 间 数 据 状态 。 

。 发 布 服务 器 有 大 量 的 插入 、 更 新 和 删除 活动 。 

发 布 服务 器 或 订阅 服务 器 不 是 SQL Server 数据 库 ( 如 Oracle) 。 

@ 合并 复制 通常 用 于 服务 器 到 客户 端的 环境 中 。 合 并 复制 适用 于 下 列 各 种 情况 : 

多 个 订阅 服务 器 可 能 会 在 不 同时 间 更 新 同一 数据 ,并 将 其 更 改 传播 到 发 布 服务 器 和 

其 他 订阅 服务 器 。 

。 订阅 服务 器 需要 接收 数据 , 脱 机 更 改 数据 ,并 在 以 后 与 发 布 服务 器 和 其 他 订阅 服务 

器 同步 更 改 。 

每 个 订阅 服务 器 都 需要 不 同 的 数据 分 区 。 

。 可 能 会 发 生 冲 突 ,并 且 在 冲突 发 生 时 需要 具有 检测 和 解决 冲突 的 能 力 。 

。 应 用 程序 需要 最 终 的 数据 更 改 结果 ,而 不 是 访问 中 间 数 据 状 态 。 

。 合并 复制 允许 不 同 站 点 自主 工作 ,并 在 以 后 将 更 新 合并 成 一 个 统一 的 结果 。 

@ 快照 复制 将 数据 以 特定 时 刻 的 瞬时 状态 分 发 ,而 不 监视 对 数据 的 更 新 。 发 生 同 步 
时 ,将 生成 完整 的 快照 并 将 其 发 送 到 订阅 服务 器 。 在 数据 更 改 量 很 大 但 很 少 发 生 时 ,快照 复 
制 是 最 合适 的 。 

(4) 说 明 如 何 使 用 系统 监视 器 监视 SQL Server 的 性 能 。 

【 答 】 利用 系统 监视 器 监视 SQL Server 的 性 能 ,一 般 采 用 如 下 的 方法 和 思路 进行 
设置 。 

Q@ 在 图 表 中 添加 或 删除 计数 器 并 保存 图 表 设 置 , 可 以 指定 系统 监视 器 启动 后 监视 的 
SQL Server 对 象 和 计数 器 。 

@ 可 以 配置 系统 监视 器 显示 任何 SQL Server 计数 器 中 的 统计 信息 。 另 外 ,可 以 为 任 
何 SQL Server 计数 器 设置 一 个 靖 值 , 当 计数 器 超过 阔 值 时 生成 一 个 警报 。 

@ 定期 监视 SQL Server 实例 可 以 确定 CPU 使 用 率 是 否 在 正常 范围 内 。 

@ 不 同 的 磁盘 控制 器 和 驱动 程序 所 用 的 内 核 处 理 时 间 不 同 。 高 效 的 控制 器 和 驱动 程 
序 所 用 的 特权 时 间 较 少 ,可 留 出 更 多 的 处 理 器 时 间 给 用 户 应 用 程序 ,从 而 提高 总 体 的 甜 
吐 量 。 

@ 检查 处 理 器 使 用 率 时 , 若 使 用 率 为 100% 左 右 ,表示 在 处 理 大 量 的 客户 端 请 求 , 可 能 
表示 进程 正在 排队 ,等 待 处 理 器 时 间 ,并 因而 导致 出 现 瓶颈 。 可 以 通过 增加 速度 更 快 的 处 理 
器 来 解决 这 一 问题 。 

(5) 介绍 监视 SQL Server 系统 时 有 哪些 主要 指标 任务 。 

【 答 】 监视 SQL Server 系统 的 主要 指标 任务 如 下 。 

g@ 监视 磁盘 LO。 磁盘 1/O 是 导致 系统 瓶颈 的 最 常见 原因 ,可 以 利用 下 面 两 个 计数 器 
进行 监视 以 确定 磁盘 活动 : Current Disk Queue Length 和 % Disk Time。 

@) 隔离 SQL Server 产生 的 磁盘 活动 。 用 户 可 以 通过 监视 以 确定 由 SQL Server 组 件 
生成 的 1/O 活动 量 ,使 用 计数 器 SQL Server: Buffer Manager: Page reads/sec 从 磁盘 读 取 第 
页 ,使 用 SQL Server: Buffer Manager: Page writes/sec 向 磁盘 写 入 页 。 
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@ 监视 CPU。 定 期 监视 Microsoft SQL Server 实例 以 确定 CPU 使 用 率 是 否 在 正常 范 
围 内 。 高 CPU 使 用 率 也 可 能 表明 应 用 程序 的 调整 或 设计 不 良 。 

@ 监视 处 理 器 的 使 用 率 。 若 使 用 率 为 100%% 左 右 , 则 表示 在 处 理 大 量 的 客户 端 请 求 , 可 
能 表示 进程 正在 排队 ,等 待 处 理 器 时 间 , 并 因而 导致 出 现 瓶颈 。 

@ 监视 内 存 。 若 要 监视 内 存 不 足 的 情况 , 则 使 用 下 列 对 象 计数 器 : 

。 Memory: Available Bytes: 指示 进程 当前 可 用 的 内 存 字 节 数 。 

。 Available Bytes 计数 器 的 值 低 表示 计算 机 总 内 存 不 足 或 应 用 程序 没有 释放 内 存 。 

。 Memory: Pages/sec: 指示 由 于 页 错误 而 从 磁盘 取 回 的 页 数 , 或 由 于 页 错误 而 写 人 

磁盘 以 释放 工作 集 空 间 的 页 数 。 

。 Pages/sec: 计数 器 的 比率 高 表示 分 页 过 多 。 

3. 上 机 练习 题 (本 题 利 用 teaching 数据 库 进 行 操作 ) 

(1) 练习 对 teaching 数据 库 进行 创建 事务 性 发 布 。 

【 答 】 对 teaching 数据 库 进行 创建 事务 性 发 布 teac_pub, 在 发 布 中 仅 选 择 teaching 数 
据 库 中 的 student 表 和 teacher 表 作 为 发 布 的 对 象 。 

主要 程序 代码 如 下 : 


-- 启用 复制 数据 库 

use [teaching] 

exec sp_replicationdboption 
@dbnanme = N'teaching'， 
@optname = N'publish'’, 
@value = N'true' 

GO 

-- 添加 事务 发 布 

use [teaching] 

exec sp_addpublication 
@publication = N'teaching- pub', 


@description = N' 来 自发 布 服务 器 "L637CEYPE9YWCSG" 的 数据 库 "teaching" 的 事务 发 布 . '， 
@sync_method = N'concurrent', 
@retention = 0, 


@allow push = N'true’, 

@allow pull = N'true', 
@allow_anonymous = N'true', 
@enabled for internet = N'false’, 
@snapshot_in_ defaultfolder = N'true’, 
@compress_snapshot = N'false', 
@ftp_port = 21, @ftp login = N'anonymous'， 
@allow_subscription copy = N'false’, 
@add to active directory = N'false', 
@repl freq = N'continuous', 

@status = N'active’, 

@independent agent = N'true’, 
@immediate sync = N'true', 
@allow_sync_tran = N'false’, 
@autogen sync procs = N'false', 
@allow_queued tran = N'false', 


@allow dts = N'false', 
@replicate ddl = 1, 


@allow initialize from backup = N'false', 


@enabled for p2p = N'false’, 
@enabled for het sub = N'false' 

GO 

exec sp_addpublication snapshot 
@publication = N'teaching- pub', 
@frequency type = 1, 
@frequency_interval = 0, 
@frequency relative interval 


上 
学 


@frequency_recurrence factor 


上 
学 


@frequency_subday = 0, 
@frequency_subday interval = 0, 
@active start time of day = 0, 
@active_end time of day = 235959, 
@active_start date = 0, 
@active_end date = 0, 
@job login = null, 
@job_password = null, 
@publisher_security mode = 1 

use [teaching] 

exec sp addarticle 
@publication = N'teaching- pub', 
@article = N'score', 
@source owner = N'dbo', 
@source object = N'score', 
@type = N'logbased', 
@description = null, 
@creation_script = null, 
@pre_creation cmd = N'drop’, 
@schema_option = 0x000000000803509F, 


@identityrangemanagementoption = N'manual’', 


@destination table = N'score', 
@destination owner = N'dbo', 
@vertical partition = N'false', 
@ins_cmd = N'CALL sp_MSins_dboscore'， 
@del cmd = N'CALL sp MSdel dboscore’, 
@upd_cmd = N'SCALL sp_MSupd_dboscore' 
GO 
use [teaching] 
exec sp_addarticle 
@publication = N'teaching- pub', 
@article = N'student', 
@source owner = N'dbo'， 
@source object = N'student', 
@type = N'logbased', 
@description = null, 
@creation script = null, 
@pre_creation cmd = N'drop’, 
@schema option = 0x000000000803509F, 
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@identityrangemanagementoption = N'manual’, 

@destination table = N'student'’, 

@destination owner = N'dbo', 

@vertical partition = N'false’, 

@ins_cmd = N'CALL sp MSins_dbostudent', 

@del cmd = N'CALL sp MSdel dbostudent', 

@upd_cmd = N'SCALL sp_MSupd_dbostudent' 
GO 


(2) 练习 创建 订阅 ,实现 对 teaching 数据 库 的 复制 。 

【 答 】 创建 实现 对 teaching 数据 库 的 复制 的 订阅 ,选择 事务 性 发 布 teac_pub, 进 行 订 
阅 。 订 阅 创建 后 ,在 发 布 服务 器 LG37CEYPE9YWCSG 的 数据 库 teaching 的 student 表 和 
score 表 中 的 数据 ,在 订阅 服务 器 LG37CEYPE9YWCSG \ SQL16 的 数据 库 teaching 的 
student 表 和 score 表 中 的 数据 随 之 更 改 ,实现 数据 同步 。 

主要 程序 代码 如 下 : 


-开始 : 要 在 发 布 服务 器 "L637CEYPE9YWCSG" 上 运行 的 脚本 

use [teaching] 

exec sp_addsubscription 
@publication = N'teaching- pub', 
@subscriber = N'LG37CEYPE9YWCSG', 
@destination db = N'teaching’, 
@sync_type = N'Automatic’, 
@subscription type = N'pull’, 
@update mode = N'read only' 

GO 

-- 结束 : 要 在 发 布 服务 器 "L637CEYPE9YWCSG" 上 运行 的 脚本 -- - 

-开始 : 要 在 订阅 服务 器 "L637CEYPE9YWCSG\SQL16" 上 运行 的 脚本 -- -- 

use [teaching] 

exec sp_addpullsubscription 
@publisher = N'LG37CEYPE9YWCSG', 
@publication = N'teaching - pub', 
@publisher db = N'teaching', 
@independent agent = N'True', 
@subscription type = N'pull', 
@description = N' 
@update mode = N'read only', 
@immediate sync = 1 

exec sp_addpullsubscription agent 
@publisher = N'LG37CEYPE9YWCSG', 
@publisher db = N'teaching'， 
@publication = N'teaching ~ pub', 
@distributor = N'LG37CEYPE9YWCSG\SQL16', 
@distributor_security mode = 1, 
@distributor login = N'', 
@distributor_ password = null, 
@enabled for_syncmgr = N'False’, 
@frequency type = 64, 
@frequency interval = 0, 
@frequency relative interval = 0, 


nl 


GO 


@frequency_recurrence factor = 0, 
@frequency subday = 0, 
@frequency_subday interval = 0, 
@active start time of day = 0, 
@active end time of day = 235959, 
@active start date = 20180227, 
@active end date = 99991231, 
@alt_snapshot folder = N"', 
@working directory = N' 

@use ftp = N'False', 

@job_login = null, 
@job_password = null, 
@publication type = 0 


(3) 练习 使 用 SQL Server Profiler 创建 跟踪 查找 执行 情况 最 差 的 查询 。 


【 答 】 


创建 跟踪 查找 执行 情况 最 差 的 查询 ,具体 步骤 如 下 : 


@ 选择 Microsoft SQL Server 2016 CTP2. 0 Profiler 命令 ,启动 SQL Server Profiler 
工具 。 选 择 “ 文 件 ” 一 “创建 跟踪 ”命令 , 并 连接 到 SQL Server 实例 。 跟 踪 名 称 
SHORTSQL ,分别 设置 “保存 到 文件 “保存 到 表 ”“ 启 用 跟踪 停止 时 间 ” 等 选项 ,如 图 14-1 


所 示 。 


LG37CEYPE9YWCSG 


Microsoft SQL Server “2016" CTP20 


版 本 : 130200 


Standard 全 认 值 ) 加 


设置 最 大 文件 大 小 MBXD): 
厅 启用 文件 滨 动 更 新 N) 
打 服务 器 处 理 跟踪 数据 旧 


Server 2016 指导 书 \SQL Server 2016 数 据 库 应 用 与 开发 指导 书 程序 sqprogam \ 第 14 章 \SHORTSGQL1403tr 量 | 


LG37CEYPE9YWCSG Rest01] (dbo] [SHORTSQL] 
厅 设置 最 大 行 歼 以 千 行为 单位 XR): 


厅 启用 跟踪 停止 时 间 人 2018/ 228 本 [2z1812 习 


14-1 创建 跟踪 SHORTSQL 


@ 选择 “事件 选择 ”选项 卡 ,选择 创建 一 个 捕获 与 TSQL 和 Stored Procedure 事件 类 
(RPC:Completed 和 SQL:BatchCompleted) 相 关 的 事件 的 跟踪 。 例 如 ,车 要 返回 适当 的 信 
息 , 则 指定 SPID、Duration、LoginName 和 ClientProcessID 数据 列 , 选 中 “显示 所 有 列 ” 复 选 
框 ,如 图 14-2 所 示 。 
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跟 符 是 性 x 
得 规 事件 选择 | 
检查 选 定 要 跟踪 的 事件 和 事件 列 。 要 查看 完整 列表 ， 请 选择 - 旦 示 所 有 事件 -和 旦 示 所 有 列 选项 。 
了 vants SPID Duration Loginllame ClientProcessID TextData | Appli JTUse， 
EStored Procedares El 
所 BPC Output Paraneter [a 5 [4 
SP:Reconpile [a a [a 
所 TSQL 
后 SQL:BatohCompleted 区 5 [a [a 
5 SQL:BatehStarting ra ra Ea 
< ES > 
-SQLBatchStaring 
启动 Transact-SQL 批 处 理 时 发 生 。 厂 显示 所 有 事件 加 
厅 显示 所 有 列 @ 
『sSystem (未 应 用 科 选 器 ) 
指示 该 事件 发 生 在 系统 进程 还 是 用 户 进程 上 。1 = 系统，0 = 用户。 列 蔽 选 器 四 . 
组 织 列 O). 
5 | ws | 


14-2 设置 跟踪 SHORTSQL 的 事件 


@ 还 可 以 单 击 “ 组 织 列 " 按 钮 ,在 弹出 的 “组 织 列 ” 对 话 框 中 改变 数据 列 的 顺序 ,如 图 14-3 
所 示 。 

@ 按照 事件 占用 时 间 Duration 分 组 并 指定 事件 准则 。 例 如 ,如 果 指 定 事件 的 Duration 
必须 至 少 为 5ym( 实 际 生产 过 程 中 该 值 应 该 大 一 些 ), 则 可 以 从 跟踪 中 清除 持续 时 间 更 短 的 
事件 。 当 然 , 也 可 以 根据 需要 增 大 Duration 的 最 小 值 ,如 图 14-4 所 示 。 


i 


向 FW) | 向 FE) 取消 职 消 
图 14-3 改变 跟踪 列 顺序 图 14-4 指定 跟踪 事件 的 准则 


回 设置 完毕 , 单 击 “ 运 行 ”按钮 ,然后 可 以 连接 数据 库 实例 LG37CEYPE9YWCSG ,在 查 
询 设计 器 中 执行 一 些 查 询 , 观 察 跟踪 SHORTSQL 的 执行 情况 ,如 图 14-5 所 示 。 

(4) 练习 使 用 SQL Server Profiler 创建 跟踪 审核 SQL Server 活动 。 

【 答 】 设置 安全 管理 员 经 常 需要 了 解 登录 到 服务 器 的 用 户 ,SQL Server Profiler 跟踪 


EI 
54 了 SQL-BatchStarting 
SQL:BatchStarting 
SQL-BatchStarting 


SQL-Batchstarting 
SQL-BatchStarting 

SQL-BatchStarting 

SQL-BatchStarting 2018-02-28 11:40:26..- 


SQL-BatchStarting 2018-02-28 11:40-26.-- 
SQL-Batchstarting 2018-02-28 11:40:26... 
SQL-BatchStarting 2018-02-28 11:40:26..- 


14-5 ”观察 跟踪 SHORTSQL 的 执行 情况 


可 以 提供 登录 到 服务 器 或 从 服务 器 注销 的 用 户 的 完整 记录 ,而 且 此 信息 可 用 于 法 律 或 技术 
目的 。 具 体 步 又 如 下 : 

@ 选择 Microsoft SQL Server 2016 CTP2. 0 Profiler 命令 ,启动 SQL Server Profiler 
工具 。 选 择 “ 文 件 ” 一 “创建 跟踪 ”命令 ,并 连接 到 SQL Server 实例 。 跟 踪 名 称 FOLLOW1， 
分 别 设置 “保存 到 文件 “保存 到 表 ”“ 启 用 跟踪 停止 时 间 ” 等 选项 ,如 图 14-6 所 示 。 


Mcrosof SOL Server “2016" CTP20 版 本 - 
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14-6 创建 跟踪 FOLLOW1 


@ 选择 “事件 选择 ”选项 卡 ,并 选择 Audit Login 事件 ,目的 是 利用 SQL Server Profiler 
跟踪 可 以 提供 登录 到 服务 器 或 从 服务 器 注销 的 记录 信息 。 例 如 , 若 要 返回 适当 的 信息 , 则 指 | 第 
定 SPID、LoginName、ClientProcessID 和 StartTime 数据 列 , 如 图 14-7 所 示 。 
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时 踪 居 性 
寓 规 。 事件 选择 


检查 计 定 要 中 中 的 事件 和 事件 列 。 要 坦 看 完整 列表， 请 选择 翌 示 所 有 事件 -和 时 示 所 有 列 计 项 % 
Statrims 


厂 显示 所 有 事件 但 
厅 显示 所 有 列 C) 


组 织 列 人 O)-- 


ww | w | 
14-7 设置 跟踪 FOLLOW1 的 事件 


@@ 设置 完毕 , 单 击 “ 运 行 "按钮 ,然后 可 以 断 开 或 连接 数据 库 实例 LG37CEYPE9YWCSG， 
观察 跟踪 FOLLOW1 的 执行 情况 ,如 图 14-8 所 示 。 


Audit Login 
Audit Login 
Audit Login Ne 
Audit Login 本 2018-02-28 11:51:51..- 
Audit Login 到 2018-02-28 11:52:16. - - 


audit Login - 2018-02-28 11:52:16... 


Audit Login 本 2018-02-28 11:52:17..- 


Audit Login 2018-02-28 11:52:17..- 


14-8 运行 跟踪 FOLLOW1 


第 15 章 | SQL Server 数据 库 应 用 系统 开发 


1. 思考 题 

(1) 简 述 软件 生命 周期 分 为 几 个 阶段 ,以 及 各 阶段 的 主要 工作 是 什么 。 

【 答 】 软件 系统 完整 的 开发 过 程 被 称 为 软件 的 生命 周期 。 在 软件 生命 周期 的 每 个 阶 
段 ,以 阶段 文档 作为 成 果 产 物 和 结束 的 标志 。 生 命 周期 中 ,任何 后 一 个 阶段 都 是 在 前 一 阶段 
成 果 的 基础 上 进行 的 ,整个 开发 过 程 是 一 个 持续 性 的 ,有 计划 .有 组 织 ` 有 依据 的 有 条 不 率 的 
过 程 。 软 件 生命 周期 的 几 个 阶段 及 各 阶段 的 主要 工作 如 下 : 

@ 可 行 性 分 析 。 通 过 对 项 目的 主要 内 容 和 配套 条 件 进行 分 析 ,提出 该 项 目 是 否 值得 投 
资 和 如 何 进行 建设 的 咨询 意见 ,为 项 目 决策 提供 依据 。 

@ 需求 分 析 。 需 求 分 析 阶 段 的 任务 是 准确 地 定义 问题 , 即 确定 “软件 系统 必须 做 什 
么 ”, 确 定 软 件 系 统 的 功能 。 

@ 设计 。 设计 阶段 可 以 再 细 分 为 概要 设计 和 详细 设计 两 个 阶段 。 

首先 是 概要 设计 阶段 ,开发 人 员 要 把 确定 的 各 项 功能 需求 转换 成 需要 的 软件 体系 结构 ， 
在 该 结构 中 ,每 个 成 分 都 是 意义 明确 的 模块 , 即 每 个 模块 都 和 某 些 功 能 需求 相对 应 。 

其 次 是 详细 设计 阶段 ,就 是 为 每 个 模块 完成 的 功能 进行 具体 描述 ,要 把 功能 描述 转变 为 
精确 的 结构 化 的 过 程 描 述 。 

@ 编码 实现 。 编 码 过 程 把 详细 设计 中 每 个 模块 的 控制 结构 转换 成 计算 机 可 以 执行 的 
程序 代码 。 

@ 测试 。 测 试 是 保证 软件 质量 的 重要 手段 。 测 试 过 程 的 任务 是 尽 可 能 多 的 发 现 系统 
中 存在 的 错误 和 缺陷 ,并 将 其 修复 。 主 要 方式 是 在 设计 测试 用 例 的 基础 上 ,检验 软件 的 各 个 
组 成 部 分 。 

@ 运行 和 维护 。 软 件 运行 过 程 中 可 能 由 于 各 方面 的 原因 ,需要 对 它 进 行 修 改 。 其 原因 
可 能 是 运行 中 发 现 了 软件 隐 含 的 错误 而 需要 修改 ; 也 可 能 是 为 了 适应 变化 了 的 软件 工作 环 
境 而 需要 做 适当 变更 ; 也 可 能 是 因为 用 户 业 务 发 生变 化 而 需要 扩充 和 增强 软件 的 功能 等 。 

(2) 简 述 数据 库 应 用 系统 开发 的 一 般 过 程 。 

【 答 】 数据 库 应 用 系统 开发 应 该 遵循 软件 的 生命 周期 过 程 。 若 从 软件 工程 的 角度 来 分 
析 ,开发 一 个 规模 较 大 的 应 用 程序 一 般 需 要 分 为 以 下 几 个 阶段 : 

@ 需求 分 析 。 通 过 对 项 目的 主要 内 容 和 配套 条 件 , 如 市 场 要 求 、 资 源 供 应 、 建 设 规模 、 
工艺 路 线 .设备 选 型 .环境 影响 .资金 筹措 .盈利 能 力 等 ,从 技术 、 经 济 ,法律 .工程 等 方面 进行 
调查 研究 和 分 析 比 较 ,为 项 目 决策 提供 依据 。 需 求 分 析 阶 段 的 任务 不 是 具体 地 解决 问题 ,而 
是 准确 地 定义 问题 , 即 确定 “软件 系统 必须 做 什么 ”, 确 定 软件 系统 的 功能 。 

@ 程序 与 数据 库 设计 。 从 程序 功能 实现 的 角度 来 说 ,概要 设计 的 核心 内 容 就 是 设计 软 
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件 的 结构 ,详细 设计 阶段 为 每 个 模块 完成 的 功能 进行 具体 描述 ,其 结果 是 对 象 模型 .动态 模 
型 和 功能 模型 。 从 数据 库 设计 与 实现 的 角度 来 说 ,就 是 对 一 个 给 定 的 应 用 环境 ,构造 优化 的 
数据 库 逻 辑 模 式 和 物理 结构 ,其 结果 就 是 概念 模型 (如 E-R 图 ) 和 数据 库 表 的 结构 等 。 

名 编码 与 测试 。 编 码 过 程 把 详细 设计 中 每 个 模块 的 控制 结构 转换 成 计算 机 可 以 执行 
的 程序 代码 ,即使 用 选 定 的 程序 开发 语言 ,把 设计 的 过 程 性 描述 翻译 为 源 程序 。 其 结果 就 是 
根据 设计 需要 搭建 软件 环境 ,并 实现 各 种 功能 模块 的 程序 表达 。 测 试 过 程 的 任务 是 尽 可 能 
多 的 发 现 系统 中 存在 的 错误 和 缺陷 ,并 将 其 修复 。 测试 从 级 别 上 可 以 分 为 单元 测试 组 装 测 
试 、 系 统 测试 和 确认 测试 。 

@ 运行 和 维护 。 软 件 维护 是 软件 生存 周期 中 时 间 最 长 的 阶段 。 软 件 运行 过 程 中 可 能 
由 于 各 方面 的 原因 ,需要 对 它 进 行 修 改 。 其 原因 可 能 是 运行 中 发 现 了 软件 隐 含 的 错误 而 需 
要 修改 ; 也 可 能 是 为 了 适应 变化 了 的 软件 工作 环境 而 需要 做 适当 变更 ; 也 可 能 是 因为 用 户 
业务 发 生变 化 而 需要 扩充 和 增强 软件 的 功能 等 。 


第 2 部 分 
SQL Server 2016 
的 常用 实践 环境 与 上 机 指导 


学 习 导 读 : 

在 本 部 分 中 ,第 16 章 主 要 介绍 SQL Server 2016 的 安装 、 
配置 和 管理 的 详细 内 容 。 第 17 章 进 一 步 介 绍 SQL Server 
2016 软件 的 管理 平台 及 菜单 、 工 具 栏 等 的 详细 操作 过 程 ,以 及 
常见 错误 信息 处 理 方 法 。 


第 16 章 安装 和 配置 SQL Server 2016 


SQL Server 2016 数据 库 的 安装 对 初学 者 来 说 是 一 个 颇 有 难度 的 过 程 ,因为 安装 过 程 
中 往往 会 出 现 一 些 诸如 兼容 性 .权限 和 硬 软件 支持 等 意 想不到 的 问题 。 因 此 ,应 该 在 安装 之 
前 做 好 充分 的 准备 ,同时 也 要 确定 好 用 户 自 身 的 需求 ,选择 合适 的 版 本 ,并 实现 合理 安装 和 
优化 配置 。 


16.1 准备 安装 SQL Server 2016 


16.1.1 安装 前 必须 清楚 的 几 个 问题 


1. 什么 是 实例 

所 谓 实例 ,就 是 一 个 虚拟 的 SQL Server 服务 器 。 每 个 实例 各 有 一 套 不 为 其 他 实例 共享 
的 系统 及 用 户 数据 库 。 应 用 程序 连接 同一 台 计 算 机 上 的 SQL Server 数据 库 引 擎 实例 的 方 
式 与 连接 远程 计算 机 上 运行 的 SQL Server 数据 库 引 擎 的 方式 基本 相同 。 由 于 实例 各 有 一 
套 不 为 其 他 实例 共享 的 系统 及 用 户 数 据 库 , 所 以 各 实例 的 运行 是 独立 的 , 互 不 影响 。 在 一 台 
计算 机 上 安装 多 个 SQL Server 实例 ,就 相当 于 把 这 台 计 算 机 模拟 成 多 个 数据 库 服 务 器 ,而 
是 这 些 模 拟 的 服务 器 是 独立 且 同 时 运行 的 。 

实例 包括 默认 实例 和 命名 实例 两 种 。 一 台 计 算 机 上 最 多 只 有 一 个 默认 实例 ,也 可 以 没 
有 默认 实例 ,默认 实例 名 与 计算 机 名 相同 ,修改 计算 机 名 会 同步 修改 默认 实例 名 ,客户 端 连 
接 默认 实例 时 ,将 使 用 安装 SQL Server 时 设置 的 实例 的 计算 机 名 。 命 名 实例 安装 与 默认 实 
例 安装 步骤 相近 ,需要 用 户 自己 对 实例 命名 ,每 台 计 算 机 可 以 安装 多 个 命名 实例 。 

2. SQL Server 的 版 本 与 安装 公共 要 求 

SQL Server 的 版 本 具有 多 样 性 ,适合 不 同 的 客户 要 求 。 不 管用 户 安装 哪个 版 本 的 SQL 
Server 2016 数据 库 产品 ,都 必须 满足 表 16-1 的 配置 要 求 。 

表 16-1 安装 SQL Server 2016 的 公共 要 求 


组 件 要 求 

SQL Server 安装 程序 安装 该 产品 需要 以 下 软件 组 件 : . NET Framework 3. 5 SP11、SQL 
Server Native Client 和 SQL Server 安装 程序 支持 文件 

SQL Server 安装 程序 要 求 使 用 Microsoft Windows Installer 4. 5 或 更 高 版 本 。 安 装 了 
软件 所 需 的 组 件 后 ,SQL Server 安装 程序 将 验证 要 安装 SQL Server 2016 的 计算 机 是 否 也 
满足 成 功 安装 所 需 的 所 有 其 他 要 求 
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续 表 
组 件 要 求 

网 络 软件 SQL Server 2016 64 位 版 本 的 网 络 软件 要 求 与 32 位 版 本 的 要 求 相同 。 支 持 的 操作 系统 
都 具有 内 置 网 络 软件 。 独 立 的 命名 实例 和 默认 实例 支持 以 下 网 络 协议 ; Shared 
memory\、Named Pipes\TCP/IP 
注意 : 故障 转移 群集 不 支持 Shared memory 

Internet 软件 | 所 有 的 SQL Server 2016 安装 都 需要 使 用 Microsoft Internet Explorer 8 SP1 或 更 高 
版 本 

虚拟 化 虚拟 机 必须 运行 本 主题 稍 后 部 分 中 列 出 的 特定 SQL Server 2016 版 本 所 支持 的 操作 
系统 

硬盘 磁盘 空间 要 求 将 随 所 安装 的 SQL Server 2016 组 件 不 同 而 发 生变 化 

驱动 器 从 磁盘 进行 安装 时 需要 相应 的 DVD 驱动 器 

显示 器 SQL Server 2016 图 形 工具 需要 使 用 VGA 或 更 高 分 辨 率 ,分 辨 率 至 少 为 1024 x768 像素 

其 他 设备 需要 Microsoft 鼠标 或 兼容 的 指针 设备 


3. SQL Server 2016 的 组 件 
SQL Server 2016 按照 其 功能 分 为 5 大 模块 ,大 型 商业 软件 按照 功能 组 件 进 行 设计 已 经 
成 为 共识 ,这 样 可 以 方便 用 户 按 照 需要 进行 选择 。 各 功能 组 件 的 简要 说 明 如 表 16-2 所 示 。 


表 16-2 SQL Server 2016 组 件 功能 简介 


组 ” 件 功能 简介 
SQL Server 数据 库 | 用 于 存储 、 处 理 和 保护 数据 的 核心 服务 ,复制 ,全 文 搜索 以 及 用 
引擎 于 管理 关系 数据 和 XML 数据 的 工具 


Analysis Services 


用 于 创建 和 管理 联机 分 析 处 理 (OLAP) 以 及 数据 挖掘 应 用 程序 
的 工具 


服务 器 组 件 0 用 于 创建 .管理 和 部 署 表格 报表 以 及 自由 格式 报表 的 服务 器 和 
客户 端 组 件 ,是 一 个 可 用 于 开发 报表 应 用 程序 的 可 扩展 平台 
Ze > 用 于 开发 和 部 署 将 个 性 化 即时 信息 发 送 给 各 种 设备 上 的 用 户 应 
Notification Services 
用 程序 
Integration Services | 用 于 移动 .复制 等 操作 的 一 组 图 形 工具 和 可 编程 对 象 
安装 用 于 客户 端 和 服务 器 之 间 通 信 的 组 件 ,以 及 用 于 DB- 
客户 端 组 件 | 连接 组 件 Library、ODBC 和 OLE DB 的 网 络 库 
SQL Server 用 于 访问 .配置 ,管理 和 开发 SQL Server 的 所 有 组 件 的 集成 环境 ， 
Management Studio | 为 不 同 层次 的 开发 人 员 和 管理 员 提 供 对 SQL Server 的 访问 能 力 
SQL Server 配置 管 | 为 SQL Server 服务 .服务 器 协议 、 客 户 端 协议 和 客户 端 别名 提 
管理 工具 理 器 供 基本 配置 管理 
SQL Server Profiler 地 机 于 图 形 用 户 界面 ,用 于 监视 数据 库 引擎 实例 或 Analysis 
Service 实例 
数据 库 引擎 优化 顾问 | 可 以 协助 创建 索引 、 索 引 视图 和 分 区 的 最 佳 组 合 
开发 工具 Business Intelligence | 用 于 Analysis Services、Reporting Services 和 Integration Services 解 
Development Studio | 决 方案 的 集成 开发 环境 
SQL Server 联机 丛书 | SQL Server 2016 的 核心 文档 
文档 和 示例 提供 数据 库 引 人 擎 、Analysis Services、Reporting Services 和 


SQL Server 示例 


Integration Services 的 示例 代码 和 示例 应 用 程序 


16.1.2 安装 SQL Server 2016 必须 注意 的 若干 事项 


数据 库 往往 作为 一 个 企业 的 软件 核心 ,对 于 数据 库 的 安装 不 仅 要 考虑 到 软 硬 件 方面 ,也 
要 做 到 防 病毒 、 防 黑客 ,以免 将 来 造成 损失 。 

1. 安装 时 必须 要 注意 的 事项 

在 安装 SQL Server 2016 时 需要 注意 以 下 几 点 。 

(1) 文件 系统 。 配 置 安全 的 文件 系统 ,使 用 恰当 的 文件 系统 可 以 增加 安全 性 。SQL 
Server 2016 要 求 安装 目录 所 在 的 磁盘 的 文件 系统 格式 为 NTFS。 对 关键 的 数据 文件 使 用 
独立 磁盘 元 余 阵 列 (RAID) 。 

(2) 磁盘 驱动 器 属性 。SQL Server 2016 不 能 安装 在 具有 只 读 属性 或 被 压缩 的 磁盘 驱 
动 器 上 。 

(3) 增强 物理 安全 性 。 物 理 和 逻辑 隔离 是 构成 SQL Server 安全 的 基础 。 若 要 增强 
SQL Server 安装 的 物理 安全 性 ,主要 包括 如 下 内 容 : 

Q@ 将 服务 器 置 于 专门 的 房间 ,未 经 授权 的 人 员 不 得 入 内 。 

@ 将 数据 库 的 主 计算 机 置 于 受 物 理 保护 的 场所 ,最 好 是 上 锁 的 机 房 , 房 中 配备 水 灾 检 
测 和 火灾 检测 监视 系统 或 灭火 系统 。 

@ 将 数据 库 安 装 在 公司 Intranet 的 安全 区 域 中 ,任何 时 候 都 不 要 直接 连接 到 Internet。 

@ 定期 备份 所 有 数据 ,并 将 副本 存储 在 远离 工作 现场 的 安全 位 置 。 

(4) 使 用 防火 墙 。 防 火 墙 是 保护 SQL Server 安装 所 不 可 或 缺 的 。 若 要 使 防火 墙 发 挥 
最 佳 效 用 ,主要 包括 如 下 内 容 : 

O 在 服务 器 和 Internet 之 间 放 置 防火 墙 。 将 网 络 分 成 若干 安全 区 域 , 区 域 之 间 用 防火 
墙 分 隔 。 先 阻塞 所 有 通信 流量 ,然后 有 选择 地 只 接受 所 需 的 通信 。 

@ 在 边界 防火 墙 上 ,始终 阻塞 发 往 TCP 端口 1433( 由 默认 实例 监视 ) 的 数据 包 和 发 往 
UDP 端口 1434( 由 计算 机 上 的 实例 之 一 监视 ) 的 数据 包 。 如 果 命 名 实例 正在 侦 听 其 他 端 
口 , 则 也 阻塞 那些 端口 。 

@ 在 多 层 环境 中 使 用 多 个 防火 墙 创建 屏蔽 子 网 。 如 果 在 Windows 域内 部 安装 服务 
器 ,请 将 内 部 防火 墙 配置 为 允许 Windows 身份 验证 。 

@ 打开 Kerberos 或 NTLM 身份 验证 所 使 用 的 端口 。 

@@ 如 果 应 用 程序 使 用 分 布 式 事务 处 理 ,必须 将 防火 墙 配置 为 允许 Microsoft 分 布 式 事 
务 处 理 协调 器 (MS DTC) 在 不 同 的 MS DTC 实例 之 间 以 及 在 MS DTC 和 资源 管理 器 (如 
SQL Server) 之 间 进 行 通信 。 

(5) 隔离 服务 。 隔 离 服务 可 以 降低 风险 ,防止 已 受到 危害 的 服务 危及 其 他 服务 。 若 要 
隔离 服务 ,主要 包括 如 下 内 容 : 

Qa 任何 时 候 都 不 要 在 域 控制 器 上 安装 SQL Server。 

@ 在 不 同 的 Windows 账户 下 运行 各 自 的 SQL Server 服务 。 

@ 在 多 层 环境 中 ,在 不 同 的 计算 机 上 运行 Web 逻辑 和 业务 逻辑 。 

(6) 创建 具有 最 低 特权 的 服务 账户 。SQL Server 安装 程序 自动 向 一 个 或 多 个 服务 账 
户 授 予 对 与 SQL Server 相关 的 文件 的 完全 控制 权限 ,以 及 对 本 地 管理 员 组 的 完全 控制 权 人 
限 。 但 是 ,通过 创建 具有 运行 SQL Server 服务 所 需 的 最 低 特 权 的 Microsoft Windows 账 章 
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户 ,可 以 将 未 经 授权 的 访问 降 至 最 低 。 

(7) 禁用 NetBIOS 和 服务 器 消息 块 (SMB)。 边 界 网 络 中 的 服务 器 应 禁用 所 有 不 必要 
的 协议 ,包括 NetBIOS 和 服务 器 消息 块 。 

@@ NetBIOS 使 用 的 端口 包括 UDP/137(NetBIOS 名 称 服务 )、UDP/138(NetBIOS 数据 
报 服务 ) 和 TCP/139(NetBIOS 会 话 服务 )。 

@ SMB 使 用 的 端口 包括 TCP/139 和 TCP/445。 

2. 安全 运行 SQL Server 的 必要 设置 

安装 完成 以 后 ,要 使 所 运行 的 SQL Server 更 加 安全 ,还 需要 进行 如 下 几 方 面 的 设置 : 

(1) 服务 账户 。 要 以 可 能 的 最 低 特权 运行 SQL Server 服务 ,将 SQL Server 服务 与 
Windows 账户 相关 联 。 

(2) 身份 验证 模式 。 连 接 SQL Server 时 要 求 Windows 身份 验证 。 

(3) 强 密码 。 即 使 使 用 Windows 身份 验证 ,也 始终 为 sa 账户 指派 强 密码 。 始 终 对 所 
有 SQL Server 账户 使 用 强 密码 。 

3. 安装 方式 的 选择 

Microsoft 公司 为 SQL Server 2016 提供 了 多 种 安装 方式 ,但 安装 用 户 必 须 具 有 管理 员 
权限 。 

(1) 用 安装 向 导 安 装 SQL Server 2016 组 件 。 本 地 用 户 使 用 安装 向 导 安 装 Server 组 件 
是 一 种 最 简单 实用 的 方法 。 只 要 依照 安装 向 导 的 提示 ,按照 步骤 执行 下 来 就 可 以 了 。 这 个 
方法 适合 大 多 数 用 户 。 

(2) 用 命令 行 安装 SQL Server 2016 组 件 。 使 用 命令 行 安装 是 一 种 高 级 的 安装 方法 , 适 
合 专业 程序 员 。 通 过 修改 安装 脚本 ,可 以 满足 各 种 安装 要 求 。 然 而 ,对 于 大 多 数 用 户 来 讲 ， 
命令 行 显得 枯燥 陌生 ,在 此 不 做 介绍 。 

(3) 远程 安装 。 对 于 企业 级 应 用 来 说 ,很 可 能 需要 进行 远程 安装 。 如 果 要 将 SQL 
Server 安装 到 远程 服务 器 上 ,可 以 通过 远程 连接 ,以 安装 向 导 或 命令 行进 行 安 装 。 采 用 这 种 
方式 与 本 地 安装 并 无 太 大 差别 。 


16.1.3 安装 过 程 中 的 常见 问题 


Microsoft 公司 为 SQL Server 2016 的 安装 提供 了 功能 强大 的 安装 向 导 和 帮助 文档 ,但 
在 实际 安装 SQL Server 2016 时 还 可 能 出 现 某 些 问 题 。 

(1) 如 何 确定 是 否 已 经 安装 了 SQL Server 2016。 一 般 来 讲 , 如 果 安 装 成 功 ,“ 开 始 " 菜 
单 中 就 会 存在 Microsoft SQL Server 2016 的 程序 组 。 也 可 选择 “管理 工具 ”一 “服务 ”命令 ， 
检查 SQL Server 2016 服务 是 否 启动 。 

(2) 出 现 “SQL Server 安装 程序 无 法 连接 到 数据 库 服 务 进行 服务 器 配置 错误 信息 。 
出 现 这 类 问题 的 可 能 原因 通常 为 端口 1433 不 可 用 。 此 时 可 以 打开 1433 端口 ,或 者 停止 其 
他 软件 对 1433 的 使 用 。 

(3) 磁盘 保护 问题 。 安 装 SQL Server 2016 之 前 ,首先 了 解 磁盘 是 否 处 于 保护 状态 。 如 
果 处 于 保护 状态 ,需要 进行 设置 ,解除 磁盘 保护 状态 后 再 进行 安装 。 


16.2 安装 过 程 


本 书 使 用 的 环境 为 Windows 10 专业 旗舰 版 ,选用 SQL Server 2016 CTP2. 0 版 本 为 安 
装 示 例 。 虽 然 存在 系统 环境 和 安装 版 本 的 不 同 , 但 是 安装 过 程 基本 相同 。 只 要 符合 
Microsoft 公司 要 求 的 软 硬 件 环境 ,都 应 该 可 以 顺利 安装 。 


16.2.1 默认 实例 的 安装 


在 做 好 安装 准备 后 ,就 可 以 进入 正式 安装 阶段 了 。 因 为 SQL Server 2016 版 本 及 功能 
选择 有 差异 ,安装 步骤 也 有 不 同 之 处 。 安 装 SQL Server 2016 CTP2. 0 默认 实例 的 步骤 
如 下 。 

(1) 插入 SQL Server 安装 盘 , 然 后 双击 根 目 录 中 的 setup. exe。 如 果 出 现 Microsoft 
SQL Server 2016 安装 对 话 框 , 单 击 “ 确 定 ” 按 钮 安装 必 备 组 件 ,并 检查 是 否 需 要 安装 
Microsoft . NET Framework 并 更 新 Windows Installer。 

(2) 必 备 组 件 安装 完成 后 ,安装 向 导 会 运行 “SQL Server 安装 中 心 " 窗 口 ,如 图 16-1 
所 示 。 


瘟 SQL Server 云 壮 中 心 = 口 


如 何 获取 SQL Server Data Tools 


SQL Server Data Tools 为 数据 库 开 发 人 员 提 供 一 个 集成 的 环境 ， 以 便 针 对 任何 SQL 
Server 平台 执行 所 有 数据 库 设计 工作 。 


系统 配置 检查 器 
启动 工具 以 检查 阳 止 成 功 安装 SQL Server 的 条 件 。 


安装 升级 顾问 
升级 顾问 构 分 析 已 安装 的 SQL Server 组 件 ， 并 确定 在 升级 到 SQL Server 2016 
CTP2.0 之 前 或 之 后 要 解决 的 问题 

联机 安装 帮助 
启动 联机 安装 文档 - 


洁 昌 如何 开 始 使 用 SQL Server 2016 CTP2.0 故障 转移 群集 
阅读 关于 如 何 开始 使 用 SQL Server 2016 CTP2.0 故障 转移 群集 的 说 明 , 


局 开始 使 用 PowerPivot for SharePoint 安装 
om Ny no eden 2 请 阿 污 有 关 如 何 安装、 配置 和 验证 PowerPivot for SharePoint 安装 的 说 明 。 


图 16-1 “SQL Server 安装 中 心 ” 窗 口 


(3) 选择 “SQL Server 安装 中 心 " 窗 口 左 侧 的 “安装 ”命令 ,进入 SQL Server 2016 的 安 
装 界面 ,如 图 16-2 所 示 。 
(4) 若 要 创建 SQL Server 2016 的 全 新 安装 , 则 单 击 “ 全 新 SQL Server 独立 安装 或 向 现 


人 安装 和 配置 SQL Server 2016 


SQL Server 2016 数据 库 应 用 与 开发 习题 解答 与 上 志 指 时 


全 新 SQL Server 
启动 向 导 ， 在 非 群 集 环境 中 安装 SQL Server 2016 CTP2.0 或 向 现 有 SQL Server 2016 
CTP2.0 实例 中 添加 功能 . 


新 的 SQL Server 故障 转移 群集 安装 
启动 向 导 ， 安 装 单 节点 的 SQL Server 2016 CTP2.0 故障 转移 群集 . 


缠 向 SQL Server 故障 转移 群集 添加 节点 
启动 向 导 ， 向 现 有 SQL Server 2016 CTP2.0 故障 转 移 群集 中 活 加 节点 , 


从 SQL Server 早期 版 本 升级 
启动 向 导 ,将 SQL Server 早期 版 本 升级 到 SQL Server 2016 CTP2.0. 


图 16-2 SQL Server 2016 安装 界面 


有 安装 添加 功能 ”链接 ,然后 单 击 * 确 定 ” 按 钮 进入 "产品 密 钥 界面 。 在 “产品 密 钥 ”界面 上 选 
择 相应 的 选项 按钮 ,这些 按钮 指示 用 户 是 安装 免费 版 本 的 SQL Server, 还 是 安装 具有 PID 
密 钥 的 产品 的 生产 版 本 ,如 图 16-3 所 示 。 


首 SQL Server 2016 CTP2.0 安装 程序 =- 口 x 


an 


图 16-3 “产品 密 钥 ”界面 


(5) 单 击 “ 下 一 步 ” 按 钮 ,进入 “许可 条 款 ” 界 面 ,如 图 16-4 所 示 。 选 中 “我 接受 许可 条 
款 ” 复 选 框 。 
症 SQL Server 2016 CTP2.0 安装 程序 到 口 x 


车 要 安装 SQL Server 2016 CTP2.0， 必 须 接 受 Microsoft 软件 许可 条 于, 


微软 预 发 行 软件 许可 条 教 国 


IMICROSOFT SQL SERVER 2016 EVALUATION COMMUNITY TECHNOLOGY PREVIEW 2 
crp2) 


这 些许 可 条 教 是 微软 公司 〈 或 您 所 在 地 的 微软 公司 的 关联 公司 ) 与 您 之 间 达 成 的 协议 * 请 阅读 条 


| 款 内 容 。 这 些 条 获 适 用 于 上 壕 预 发 行 软 件 ， 包 括 您 用 来 接收 该 软件 的 介质 〈 如 果 有 ) 。 这 些 条 蒜 
也 适用 于 微软 为 该 软件 提供 的 任何 


本 EE] 
复制 (打印 (P) 
回 我 接 委 许可 冬 款 (局 . 


Lum on Telemetry and Error Reporting to help improve the quality, reliabilty and 
Performance of Microsoft SQL Server 2016 CTP2.0. 


* Microsoft SQL Server 2016 CTP2.0 also includes a Visual Studio component that will have 
telemetry settings turned on by default. If Visual Studio is installed, this component will use the 
Visual Studio Customer Experience Improvement Program (VSCEIP) settings. 


16-4 “许可 条 款 ”界面 


(6) 单 击 “ 下 一 步 "按钮 ,进入 "安装 规则 ?界面 ,如 图 16-5 所 示 。 单 击 “ 显 示 详 细 信 息 ” 
按钮 ,可 以 查看 信息 报表 。 在 这 个 界面 中 将 会 显示 安装 程序 所 支持 文件 的 通过 情况 。 


疼 SQL Server 2016 CTP2.0 雪 装 程序 总 口 x 


安装 得 序 规则 慰 ;在 运行 安装 全 序 时 可 能 发 生 的 同 题 。 作 须 更 下 所 有 条 败 ， 去 丢 全 证 能 堆 过 - 


操作 完成 。 已 通过 : 5。 失 骆 0 车 告 0 已 跳 过 0. 

[| 

ageG >> | [mzs® | 
各 查看 详细 握 表 [V) 


图 16-5 “安装 规则 ”界面 和 


颁 灼 和 配置 SQL Server 2016 


SQL Server 2016 数据 亩 应 用 与 开发 习题 解答 与 上 志 指 时 


(7) 单 击 “ 下 一 步 ” 按 钮 ,进入 “设置 角色 ”界面 ,如 图 16-6 所 示 。 


SQL Server 2016 CTP2.0 去 装 得 序 二 “上 党 


轿 SQL Server 功能 去 甘 (5) 
安装 SQL Server 数据 库 引 | 学 服务 、Analysis Services、Reporting Services. Integration Services 
和 他 功能 . 


口上 只 有 默认 值 的 所 有 功能 (D) 
使 用 服务 帐户 的 默认 全 安装 所 有 功能 . 


EE 


< 上 一 步 (B 下- 步 (和) > 取消 帮助 


16-6 “设置 角色 ”界面 


(8) 单 击 “ 下 一 步 ” 按 钮 ,进入 “功能 选择 "界面 ,在 其 中 可 以 根据 需要 选中 “功能 ”列表 框 
中 的 具体 功能 , 右 侧 窗 格 中 会 显示 每 个 组 件 的 说 明 , 如 图 16-7 所 示 。 


稀 SQL Server 2016 CTP2.0 去 装 得 序 过 口 x 


功能 说 明 : 
SQL Server 实例 的 每 个 实例 功能 的 配置 和 担 。 人 
作者 与 其 他 SQL Server 实例 分 开 . 园 
SQL Server 实例 可 以 在 同一 各 计 算 机 上 并 行 Y 
所 选 功能 的 4 备 组 件 (P): 
安装 规则 经 去 先 各 
设 杆 角色 |- Windows PowerShell 20 ~ 
“ sm > 
功能 选择 
ga 磁盘 空间 要 求 (D) 
回 Reporting Services - SharePoint 上 a 
二 sc ss 司 用 
服务 器 本 置 « i > 
数 振 库 引 芝 配置 
Analysis services 配置 SE(N 全 部 不 选 (U) 
Reporting Services 配置 实例 根 目 录 (R): CA\Program Files\Microsoft SQL Serve\ 区 
Distributed Replay 控制 器 
istrit Replay 害 户 泊 共享 功能 目录 (S): Ci\Program Files\Microsoft SQL Server\ 
功 醒 于 规则 共享 功能 目录 (x86)00: [CAProgram Files (x86)\Microsoft SQL Server\ 过 


| < | | SV > | | 了 二 


16-7 “功能 选择 ”界面 


其 中 ,对 话 框 下 面 的 “共享 功能 目录 ”为 共享 组 件 设置 共享 功能 的 目录 信息 。 用 户 要 想 
更 改 共 享 组 件 的 安装 路 径 ,可 以 重新 输入 新 的 目录 名 ,也 可 以 单 击 “ 浏 览 ” 按 钮 选择 一 个 新 的 
安装 上 日 录 。 系 统 默 认 的 安装 路 径 为 C:\Program Files\Microsoft SQL Server\。 在 “功能 选 
择 ” 界 面 中 单 击 “ 全 选 ” 按 钮 , 则 会 选中 SQL Server 2016 中 的 所 有 功能 ; 如 果 单 击 “ 全 部 不 
选 ? 按 钮 ,将 会 取消 所 有 选中 的 功能 。 

(9) 单 击 “ 下 一 步 ” 按 钮 ,进入 “实例 配置 "界面 ,用 户 可 以 选择 安装 默认 实例 或 者 命名 实 
例 ,选中 “默认 实例 ” 单 选 按钮 ,如 图 16-8 所 示 。 


黎 SQL Server 2016 CTP2.0 安装 程序 站 口 x 


Wsk 〇 宫 名 安全 (A}: MSSQLSERVER 

全 局 规则 

产品 更 新 国 
安装 安装 程序 文件 实例 IDOD): IMSSQLSERVER 

安装 规则 

设置 角色 

功能 寺 摊 SQL Server 目录 : CNProgram Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER 
功能 规则 Analysis Services 目录 :Ci\Program Files\Microsoft SQL Server\MSAS13.MSSQLSERVER 
实 便 配置 Reporting Services 目录 Ci\Program Files\Microsoft SQL Server\MSRS13.MSSQLSERVER 
服务 器 配 杜 

二 村 一 已 安 对 的 实 9(L: 

Anaysis Services 配 轩 实 卫 名 称 实 到 1D _ 了 _ 版 本 类 到 版 本 
Reporting Services 配置 

Distributed Replay 控制 器 

Distributed Replay 客户 沪 

功能 本 轩 规则 


图 16-8 “实例 配置 "界面 


Q@ 默认 实例 。 系 统 默认 情况 下 ,用 户 在 第 一 次 安装 SQL Server 时 安装 的 是 默认 实例 ， 
默认 实例 名 为 MSSQLSERVER ,系统 可 以 通过 计算 机 的 名 称 来 识别 默认 实例 。 

@ 命名 实例 。 当 对 SQL Server 实例 进行 命名 时 ,实例 名 不 区 分 大 小 写 ; 实例 名 称 不 能 
包含 保留 关键 字 ; 实例 名 限制 为 16 个 字符 ; 实例 名 中 的 第 一 个 字符 必须 是 字母 ; 实例 名 称 
中 不 允许 含有 空格 或 其 他 特殊 字符 ,也 不 允许 存在 反 斜 杠 、 豆 号、 冒号 、 分 号 、 单 引号 等 。 

@ 实例 ID。 默 认 情 况 下 ,实例 名 称 用 作 实例 ID。 对 于 默认 实例 ,实例 名 称 和 实例 ID 
为 MSSQLSERVER。 若 要 使 用 非 默认 的 实例 ID, 则 在 “实例 ID? 字 段 中 指定 它 。 

@ 实例 根 目 录 。 默 认 情 况 下 ,实例 根 目录 为 C:\Program Files\Microsoft SQL Server\。 
若 要 指定 非 默认 的 根 目 录 , 则 单 击 “浏览 ?按钮 或 提供 一 个 路 径 名 。SQL Server 的 给 定 实例 
的 所 有 组 件 作为 一 个 单元 进行 管理 。 所 有 SQL Server Service Pack 和 升级 都 将 应 用 于 
SQL Server 实例 的 每 个 组 件 。 

@ 已 安装 的 实例 。 该 网 格 将 显示 运行 安装 程序 的 计算 机 上 的 SQL Server 实例 。 如 果 
计算 机 上 已 经 安装 了 一 个 默认 实例 , 则 必须 安装 SQL Server 的 命名 实例 。 

(10) 单 击 * 下 一 步 ?按钮 ,进入 "服务 器 配置 ?界面 ,用 户 可 以 通过 “服务 账户 ?选项 卡 设置 


人 妥 装 和 配置 SQL Server 2016 


SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 志 指 时 


各 个 服务 的 账户 和 密码 ,密码 也 可 以 为 空 。 对 SQL Server 服务 进行 配置 ,每 个 服务 可 以 配置 
相同 的 登录 账户 ,也 可 以 分 别 配 置 不 同 的 账户 ,在 “启动 类 型 ? 列 中 可 以 选择 手动 和 自动 两 种 。 
建议 对 各 个 服务 账户 进行 单独 配置 ,以 便 为 每 项 服务 提供 最 低 特权 ,也 就 是 向 SQL Server 服 
务 授予 它们 完成 各 自任 务 所 需 的 最 低 权限 ,如 图 16-9 所 示 。 为 了 方便 初学 者 安装 并 使 用 ,本 
例 对 所 有 的 服务 都 选择 NETWORK SERVICE, 对 排序 规则 不 作 更 改 , 如 图 16-10 所 示 。 


首 SQL Server 2016 CTP2.0 安装 得 序 过， ,如 X 
服务 器 配置 
指定 服务 相关 和 捧 序 规则 配置 . 
产品 密 钥 服务 帐户 排序 规则 
1 Microsoft 建议 等 对 每 个 SQL Server 服务 使 用 一 个 单 狐 的 帐户 (M). 
产品 更 新 服务 相关 名 E33 启动 型 


安 半 规则 SQL Server 政纪 库 引 | 萤 NT Service\MSSQLSE.. 
设置 角色 SQL Server Analysis Services 。 |NT Service\MSSQLSer.. | 
功能 渤 控 SQL Server Reporting Services “|NT Sevice\ReportSer.. 
功名 规则 
实 WE 


SQL Server Integration Service.. |NT Service\MsDtsServ.. 
SQL Server Distributed Replay -- |NT Service\sQL Serve.. | 
SQL Server Distributed Replay -| NT Service\SQL Serve.. 


16-9 “服务 器 配置 "界面 


首 SQL Server 2016 CTP2.0 安装 程序 - DO x 
| 
指证 最 务必 户 和 举 序 规 则 配 杜 . 

Li 服务 帐户 | 持 序 规则 | 

数 委 二 | 本 (D)}: 加 
产品 更 新 [Chinese PRC CI AS 特定 XGO- 
安装 安装 但 序 文件 Latin1-General， 不 区 分 大 小 写 ， 区 分 重音 ， 不 区 分 估 名 类型 ，Unicode 数据 不 

三 区 分 全 半角 ， 非 Unicode 数据 的 代 三 页 1252 上 SQL Server 排序 响 训 52 

设置 角色 Analysis Services(A): 

St [Chinese PRC CLAS | 和 定义 (W-- | 

Latin1-General， 不 区 分 大 小 写 ， 区 分 重音 ， 不 区 分 全 名 关 型 ,不 区 分 全 半角 

ER 营 车 : 数 妆 引 莘 和 Anahzis Services 排序 规则 不 同 . 

六 3 亩 本 各 

Analysis services 配置 

Reporting Services 配置 

Distributed Replay 控制 器 

Distibuted Replay 套 广 庙 

家 机理 规 则 


[= 是 || 下 和 > | | 0 


图 16-10 ”排序 规则 


(11) 车 要 启动 和 运行 SQL Server 中 的 每 项 服务 ,这 些 服务 都 必须 有 一 个 在 安装 过 程 
中 配置 的 账户 。 用 于 启动 和 运行 SQL Server 的 启动 账户 可 以 是 内 置 系统 账户 、 本 地 用 户 账 
户 或 域 用 户 账户 。 

中 Domain User 账户 。 如 果 服 务必 须 与 网 络 服务 进行 交互 , 则 访问 类 似 于 文件 共享 的 
域 资源 ; 如 果 服 务 使 用 到 运行 SQL Server 的 其 他 计算 机 的 链接 服务 器 连接 , 则 可 以 使 用 具 
有 最 低 特权 的 域 账户 。 

@ Local User 账户 。 如 果 计 算 机 不 在 域 中 , 则 建议 使 用 不 具有 Windows 管理 员 权 限 
的 本 地 用 户 账户 。 

@ Local Service 账户 。Local Service 账户 是 一 个 内 置 账户 ,与 Users 组 的 成 员 具 有 相 
同 级 别 的 资源 和 对 象 访问 权限 。 

@ Network Service 账户 。Network Service 账户 是 一 个 内 置 账 户 , 比 Users 组 的 成 员 
拥有 更 多 的 对 资源 和 对 象 的 访问 权限 。 

@ Local System 账户 。Local System 账户 是 一 个 具有 高 特权 的 内 置 账户 , 它 对 本 地 系 
统 拥 有 许多 权限 并 作为 网 络 上 的 计算 机 。 

默认 情况 下 ,对 于 故障 转移 群集 安装 和 命名 实例 ,SQL Server Browser 设置 为 在 安装 
程序 完成 后 自动 启动 。 

用 户 可 以 为 每 个 服务 设置 单独 的 账户 和 密码 ,也 可 以 对 所 有 的 服务 使 用 一 个 账号 。 如 
果 为 每 个 服务 设置 单独 的 账号 ,可 以 从 “账户 名 ”列表 框 中 选择 账户 名 称 。 此 外 ,用 户 还 可 以 
在 “密码 ”文本 框 中 设置 服务 的 密码 ,在 “启动 类 型 "列表 框 中 选择 启动 类 型 。 服 务 的 启动 类 
型 分 为 手动 、 自 动 和 禁用 三 种 类 型 。 

Microsoft 公司 建议 对 每 个 服务 设置 单独 的 账户 ,从 而 保证 向 SQL Server 服务 授予 它 
们 完成 各 自任 务 的 最 低 权 限 。 

若 要 对 所 有 SQL Server 服务 使 用 相同 的 账户 ,可 以 单 击 * 对 所 有 SQL Server 服务 使 用 
相同 的 账户 ”按钮 ,弹出 账户 设置 对 话 框 。 用 户 可 以 在 “账户 名 ”文本 框 中 输入 用 户 名 ,或 者 
从 下 拉 列 表 框 中 选择 用 户 , 也 可 以 单 击 “ 浏 览 ” 按 钮 ,进入 “选择 用 户 或 组 ”对 话 框 。 

(12) 单 击 “下 一 步 ?按钮 ,进入 "数据 库 引擎 配置 "界面 ,如 图 16-11 所 示 。 

@D Windows 身份 验证 模式 。 当 用 户 通过 Windows 用 户 账户 连接 时 ,SQL Server 使 用 
操作 系统 中 的 Windows 主体 标记 验证 账户 名 和 密码 。 此 为 默认 身份 验证 模式 , 比 混合 模式 
更 为 安全 。Windows 身份 验证 利用 Kerberos 安全 协议 ,通过 强 密码 的 复杂 性 验证 提供 密 
码 策 略 ,提供 账户 锁定 支持 ,并 且 支 持 密码 过 期 。 

@ 混合 模式 (Windows 身份 验证 或 SQL Server 身份 验证 ) 。 人 允许 用 户 使 用 Windows 
身份 验证 或 SQL Server 身份 验证 进行 连接 。 通 过 Windows 用 户 账户 进行 连接 的 用 户 可 以 
使 用 经 过 Windows 验证 的 可 信 连 接 。 

如 果 必 须 选择 “混合 模式 ”并 且 要 求 使 用 SQL 登录 名 以 适应 早期 应 用 程序 , 则 必须 为 所 
有 SQL Server 账户 设置 强 密码 。 

@ 在 “数据 库 引 擎 配置 ?界面 中 指定 以 下 各 项 。 

。 安全 模式 。 为 SQL Server 实例 选择 Windows 身份 验证 或 混合 模式 身份 验证 。 如 

果 选 择 “ 混 合 模式 ”, 则 必须 为 内 置 SQL Server 系统 管理 员 账 户 提供 一 个 强 密码 。 
在 设备 与 SQL Server 成 功 建立 连接 之 后 ,用 于 Windows 身份 验证 和 混合 模式 身份 
验证 的 安全 机 制 是 相同 的 。 
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葡 SQL Server 2016 CTP2.0 去 装 程序 


服务 吉本 于 数 大 目录 FILESTREAM 
为 到 括 寺 引擎 指定 身份 痊 证 楼 式 和 管理 员 - 
身份 验证 模式 


图 Windows 身份 验证 模式 (W) 

〇 浊 合 模式 (SQL Server 身份 验证 和 Windows 身份 验 下 (M) 
为 SQL Server 系统 管理 员 (sa) 帐 户 揪 定 密码 . 

输入 这 码 (E: 

确认 密码 (Oj}: 

所 十 SQL Server 管理 员 


16-11 


“数据 库 引擎 配置 界面 


。 SQL Server 管理 员 。 用 户 必 须 至 少 为 SQL Server 实例 指定 一 个 系统 管理 员 。 用 户 
可 以 单 击 “ 添 加 当前 用 户 ” 按 钮 ,也 可 以 单 击 “ 添 加 "或 “删除 ”按钮 来 管理 SQL 
Server 实例 的 系统 管理 员 用 户 。 

需要 注意 的 是 , 尽 可 能 使 用 Windows 身份 验证 ,不 要 使 用 空 密 码 。 最 好 使 用 强 密码 , 切 


勿 设置 空 密码 或 弱 sa 密码 。 

用 户 还 可 以 通过 “数据 目录 ”选项 卡 来 设置 安装 目录 ,如 图 16-12 所 示 。 

区 SQL Server 2016 CTP2.0 安装 程序 o x 
数据 库 引擎 配置 
| 
指定 数据 库 引 草 身份 验证 安全 模式 、 若 理 员 和 数据 目录 . 
产品 密 铜 服务 器 配置 数据 目录 FILESTREAM 
许可 科 吉 
全 局 规则 数据 根 目录 (D): CNprogram Files\Microsoft SQL Server\ ~ 
产品 更 新 系统 数据 库 目录 (S): Ci\Program Files\Microsoft SQL 
和 件 Server\MSSQL13.MSSQLSERVER\MSSQL\Data 
安 壬 规则 用 户 数 迫 库 有 目录 (U): 。 |CNprogram Files\Microsoft SQL ServerMSSQL13.MSSQLSERV| 
is 用 户 数 舌 库 日 志 目 录 (U: [C:\Program Files\Microsoft SQL ServeAIMSSQL13.MSSQLSERVI| 
临时 数据 库 目 录 (D:。。 |CNprogram Files\Microsoft SQL Server\MSSQL13.MSSQLSERV| 
临时 数据 库 日 志 目 录 (Ej: |CNProgram Files\Microsoft SQL Server\MSSQL13.MSSQLSERVI| 
数据 库 引擎 配 辕 备份 目录 (K): CNPregram Files\Microsoft SQL Server\MSSQL13.MSSQLSERV] 
Analysis Services 配置 | 
Reporting services 配置 SS - 
Vy 此 值 可 增加 到 内 校 至 
Distributed Replay 控制 守 认 值 为 8 或 内 核 笋 (名 较 小 什 ). 
Distributed Replay 客户 镁 
功 部 本 二 规则 
< SV>|| BN | #0 
图 16-12 “数据 目录 ”选项 卡 


(13) 单 击 “ 下 一 步 ” 按 钮 ,进入 “Analysis Services 配置 "界面 ,如 图 16-13 所 示 。 


黎 SQL Server 2016 CTP2.0 安装 导 序 - 0O x 


16-13 “Analysis Services 配置 ?界面 


用 户 必须 为 SQL Server 实例 至 少 指定 一 个 系统 管理 员 。 若 要 添加 当前 正在 运行 SQL 
Server 安装 程序 的 账户 , 单 击 * 添 加 当前 用 户 ?按钮 。 若 要 添加 其 他 用 户 或 服务 , 单 击 “ 添 加 ”按钮 ， 
然后 为 需要 管理 权限 的 用 户 或 服务 输入 Windows 域 用 户 账户 。 若 要 从 系统 管理 员 列 表 中 删除 账 
户 , 单 击 “ 删 除 ” 按 钮 ,然后 编辑 对 SQL Server 的 实例 拥有 管理 员 特 权 的 用 户 ,组 或 计算 机 的 列表 。 

(14) 单 击 “ 下 一 步 ” 按 钮 ,进入 “Reporting Services 配置 ?界面 ,如 图 16-14 所 示 。 用 户 
根据 需要 选择 Reporting Services 的 安装 类 型 。 


条 SQL Server 2016 CTP2.0 安装 得 序 一 口 x 
Reporting Services 配置 
天 证 Reporting Services 配 轨 秋 式 . 
产品 鹿角 | Reporting services 李 机 模式 
WK 国安 半 和 本 杆 ( 口 . 
全 局 规则 在 二 机 模式 中 安装 和 配 轩 报表 最 务 器 报表 了 务 器 棕 在 安 符 成 后 正常 运 行 。 
产品 更 新 口 仅 安 闭 (O). 
安装 雪 半 程序 文件 去 装 报 表 最 务 加 文件。 安生 交友 后 ， 使 用 Reporting Services 配 半 管理 吉本 半 报表 最 务 车 用 
Pa 于 二 
设置 角色 Reporting Services SharePoint 集成 模式 
ee ® re 
ms 安装 报表 服 务 天 文件 ， 安 壮 计 太后， 使 用 Sharepoint 管理 中 心志 或 配种. 铀 认 SQL Server 
EE Reporting Services 服务 已 启动 并 且 创 建 至 少 一 个 SQL Server Reporting Services 服务 应 用 
ni 程 术 ,有 关 洋 把 千 息 ， 请 半 去 -大 
NE 二 引 李 配 于 
Analysis services 配置 
Reporting Services 配置 
Distributed Replay 控制 器 
Distributed Replay 要 户 入 
本 下 观 则 
[Es | FD> 取 | 寺 凤 第 
图 16-14 “Reporting Services 配置 ?界面 章 
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(15) 单 击 “下 一 步 ” 按 钮 ,进入 “Distributed Replay 控制 器 ”界面 ,指定 Distributed 
Replay 控制 服务 器 的 控制 权限 ,如 图 16-15 所 示 。 


首 SQL Server 2016 CTP2.0 安装 程序 三 口 X 


Distributed Replay 控制 器 
指定 Distributed Replay 控制 器 服务 的 访问 权限 . 


产品 密 钥 指定 万 些 用 户 具 有 对 Distributed Replay 控制 天 服 务 的 权限 。 


许可 条 欢 [tS37cevPeovwcsG Wdministrator Administraton 


添加 当前 用 户 (|| 添 I | 和 je(R) | 


16-15 “Distributed Replay 控制 器 ”界面 


(16) 单 击 “ 下 一 步 ”按钮 ,进入 “Distributed Replay 客户 端 "界面 ,为 客户 端 指定 控制 器 
和 目录 信息 ,如 图 16-16 所 示 。 


首 SQL Server 2016 CTP2.0 安装 程序 口 X 
Distributed Replay 客户 端 
为 Distributed Replay 喜 户 针 措 定 相应 的 控制 器 和 数 委 目录 
sd 指定 控制 路 计算 机 的 饼 你 和 目录 位 置 . 
人 控制 器 名 称 (O: | 
全 局 规则 
产品 更 新 工作 目录 (W): |CNProgram Files (x86)\Microsoft SQL Server\DReplayClient\WorkingDir\| | 二 
安装 安装 程序 文件 结果 目录 (R): CNpProgram Files (x86)\Microsoft SQL Server\DReplayClient\ResultDir\ _ 
安 先 规则 
设置 角色 
i 
eR 
实权 
服务 吉本 村 
le 
Analysis Services 配置 
Reporting Services 配置 
Distributed Replay 控制 器 
Distributed Replay 客户 污 
本 于 规则 
[|< | 下 上 > | | my 二 


图 16-16 “Distributed Replay 客户 端 ? 界 面 


(17) 单 击 “ 下 一 步 ” 按 钮 ,进入 “准备 安装 ”界面 ,用 户 在 这 里 将 看 到 在 安装 过 程 中 指定 
的 安装 选项 的 树 形 视图 ,如 图 16-17 所 示 。 


首 SQL Server 2016 CTP2.0 去 装 程 序 = 口 X 
验证 要 安装 的 SQL Server 2016 CTP2.0 功能 . 
产品 密 钥 已 准备 好 安装 SQL Server 2016 CTP2.0: 
许可 条 款 己 拓 要 
全 局 规则 版 本 类别 : Evaluation | 
产品 更 新 握 作 : Install (产品 更 新 ) 
甘 妆 奖 程序 文件 br 
日 ge 雪 奖 
bi Windows powerShell 20 
设置 角色 Microsoft NET Framework 3.5 
功能 选择 Microsoft Visual Studio 2010 可 再 发 行 组 件 
规则 — Microsoft NET Framework 45 
SE 日 要 从 介 括 安装. 
Microsoft Visual studio 2010 Shell 
服务 部 本 于 Microsoft Visual Studio Tools for Applications 30 
nl 上 革 规 时 二 
Analysis Services 配置 白 功 甬 
Reporting Services 配置 和 启 引 | 过 服务 吕 
Distributed Replay 控制 器 PE > 
Distributed Replay 客户 并 瑟 杆 文件 路 径 : 
OE CAprogram Files\Microsoft SQL Server\130\Setup Bootstrap\Log\20180218.153156\Configuration| 
| | 岗 


16-17 “准备 安装 ”界面 


(18) 单 击 “ 安 装 ” 按 钮 ,进入 “安装 进度 ”界面 ,用 户 将 在 这 里 看 到 安装 过 程 进 度 和 相应 
的 状态 ,如 图 16-18 所 示 。 


午 SQL Server 2016 CTP2.0 安装 得 序 - 0 x 


lnstall sqltools_loc_Cpu54_2052_Action : MsipublishAssemblies. 正在 发 布 程序 抹 信息 
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(19) 安装 完成 后 将 会 弹出 “完成 ”界面 ,提示 SQL Server 2016 CTP2. 0 已 经 成 功 安装 
完成 ,如 图 16-19 所 示 ,并 且 把 摘要 日 志文 件 保 存 到 了 相应 的 目录 中 ,用 户 可 以 打开 查看 。 
单 击 “ 关 闭 ” 按 钮 完成 安装 。 


首 SQL Server 2016 CTP2.0 安装 程序 —- OO x 

完成 

SQL Server 2016 CTP2.0 安装 已 成 功 完 成 帝 产 品 更 新 。 

| 关于 安装 程序 要 作 或 可 能 的 随后 步 邓 的 信息 ()): 
许可 委 款 i 
全 局 规则 
产品 更 新 则 本 
ee OIR sok 成 了 
去 半 规则 固守 户 尖 T 具 向 后 茹 安 性 成 功 
设置 角色 后 mmT 且 -at 5 | 
功 角 迁 择 
Ti 详细 信息 (Dj 
实 f 醒 轩 
服务 器 配置 
数据 库 引 芝 配置 
Analysis Services 配置 

Reporting Sevices 配置 

Distributed Replay 控制 器 

Dierboled Repley 入 广 久 已 格拉 要 日 志文 件 保存 到 以 下 位 置 : 
功 lg 卫 填 规 则 CAProgram Files\Microsoft SQL Server\130\Setup BootstrapMLog\20180218 153156 

YSummary LG37CEYPE9YWCSG 20180218 153156.txt 


图 16-19 “完成 ”界面 


若 要 从 网 络 共享 进行 安装 , 则 应 找到 共享 中 的 根 目录 ,然后 双击 setup. exe。 安 装 远程 
客户 端 ,只 要 在 开始 安装 的 界面 上 选择 “运行 SQL Native Client 安装 向 导 ” 选 项 即 可 。 安 装 
过 程 简单 ,在 此 不 再 袭 述 。 

16.2.2 命名 实例 的 安装 


SQL Server 2016 支持 单个 或 多 个 服务 器 上 安装 多 个 实例 ,但 只 能 有 一 个 默认 实例 ,其 
他 都 是 命名 实例 。 命 名 实例 的 安装 过 程 和 默认 实例 相近 ,只 是 在 如 图 16-8 所 示 的 “实例 配 
置 ?界面 中 选择 “命名 实例 ,并 输入 实例 名 即 可 。 


16.3 配置 服务 器 选项 


16.3.1 网 络 连接 方式 的 选择 与 配置 


SQL Server 2016 安装 程序 提供 了 智能 安装 服务 ,但 有 些 SQL Server 的 用 户 仍 然 可 能 
需要 手动 更 改 或 配置 SQL Server 2016 服务 器 的 网 络 连接 。 下 面 就 影响 SQL Server 2016 
网 络 连 接 属性 的 因素 进行 简要 介绍 。 


使 用 何 种 网 络 协议 和 防火 墙 的 配置 情况 是 与 一 台 SQL Server 数据 库 服 务 器 建立 连接 
时 必须 考虑 的 主因 素 。 一 方面 ,期 望 有 一 种 方式 能 够 轻松 地 与 数据 库 服务 器 建立 连接 , 另 一 
方面 又 希望 配置 的 数据 库 服务 器 能 够 尽 可 能 地 抵挡 各 种 来 自 网 络 的 攻击 。 但 不 幸 的 是 ,这 
两 种 期 望 恰恰 是 对 立 的 。 因 此 ,结合 自身 的 需求 为 SQL Server 2016 数据 库 选择 一 个 合理 
的 配置 才 是 解决 上 述 矛 盾 的 唯一 出 路 。 

SQL Server 2016 服务 器 为 客户 端 应 用 程序 连接 自身 提供 了 多 种 网 络 协议 ,其 中 包括 
TCP/IP 协议 、 命 令 管道 (Named Pipes) 共享 内 存 (Shared Memory) 以 及 HTTP。 此 外 ,如 
果 和 希望 用 户 可 以 通过 远程 连接 的 方式 访问 一 台 SQL Server 2016 数据 库 ,就 需要 开启 该 数 
据 中 的 TCP/IP 或 Named Pipes 协议 。 

如 果 在 建立 与 数据 库 服务 器 的 连接 中 出 现 了 故障 ,那么 很 有 可 能 与 防火 墙 的 设置 相关 。 
此 时 需要 检查 防火 墙 设置 ,以 放行 SQL Server 2016 组 件 访问 网 络 的 操作 和 它们 侦 听 的 端 
口 。 需 要 注意 的 是 ,默认 情况 下 ,SQL Server 2016 数据 库 服务 器 侦 听 的 TCP 端口 为 1433 。 

1. 配置 SQL Server 服务 器 的 网 络 连接 的 工具 

SQL Server 2016 为 用 户 更 改 和 配置 SQL Server 2016 服务 器 的 网 络 连 接 提供 了 相应 
的 配置 工具 , 即 SQL Server Configuration Management 和 “外 围 应 用 配置 器 ”。 

(1) SQL Server Configuration Manager 是 一 个 图 形 化 工具 ,便于 数据 库 管理 员 对 SQL 
Server 2016 数据 的 各 个 方面 (服务 .网 络 配置 等 属性 ?进行 管理 。 通 过 该 工具 可 以 根据 需要 
配置 SQL Server 数据 库 服务 器 侦 听 时 使 用 的 协议 和 端口 ,以 及 客户 端 访 问 该 服务 器 时 需要 
使 用 的 网 络 协议 。 例 如 ,如 果 期 望 用 户 可 以 通过 远程 连接 的 方式 连接 SQL Server 2016 数 
据 库 ,就 需要 SQL Server 2016 数据 库 服务 器 能 够 侦 听 TCP 连接 。 

(2) 外 围 应 用 配置 器 。 选 择 ” Microsoft SQL Server 2016 CTP2. 0 配置 管理 器 ”命令 ， 
打开 SQL Server Configuration Manager 窗口 ,如 图 16-20 所 示 。 从 其 左 侧 的 控制 列表 中 
可 以 看 出 ,SQL Server Configuration Manager 为 数据 库 用 户 提 供 了 三 类 配置 选项 ,分 别 
如 下 。 


局 Sql Server Configuration Manager 一 口 " 
文件 (月 ” 扣 作 (A) 查看 (V) 帮助 (H) 
和 哆 | 血 | 国 回 思 | 


者 SQL server 配置 千 理 里 (本 地 ) 协议 名 称 状态 
目 SQL Server 服务 术 Shared Memory 已 启用 
县 SQL Server 网 络 配置 (32 位 ) 术 Named pipes 已 启用 
》 曙 .SQL Native Client 11.0 配置 (32 位 ) 术 Tcpnp 已 启用 
~ 县 SQL server 网 络 本 加 
好 MssQLsERVER 的 协议 


》 时 .SQL Native Client 11.0 配置 


16-20 SQL Server 配置 管理 器 
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@ SQL Server 2016 配置 管理 器 : 主要 用 于 配置 SQL Server 2016 提供 的 各 项 服务 , 例 
如 数据 库 服务 数据库 分 析 服 务 和 数据 库 报 表 服 务 等 。 

@ SQL Server 2016 网 络 配置 : 主要 用 于 配置 SQL Server 2016 数据 库 使 用 的 网 络 
协议 。 

@ SQLNative Client11.0 配置 : 主要 用 于 完成 SQL Server 2016 数据 库 客 户 端的 配置 
工作 ， 

下 面 主要 介绍 与 SQL Server 2016 网 络 配置 相关 的 各 项 设置 。 

选择 “SQL Server 2016 网 络 配 置 " 下 的 “MSSQLSERVER 的 协议 ?节点 , 窗 体 右 侧 给 出 
了 SQL Server 数据 库 服 务 器 当前 启用 的 网 络 协议 及 其 状态 。 

2. 网 络 协议 及 其 配置 

在 SQL Server Configuration Manager 中 配置 上 述 协议 的 工作 非常 简单 ,只 需 双 击 相 
应 的 协议 选项 即 可 对 其 进行 配置 。 下 面 分 别 介 绍 各 种 网 络 协议 的 配置 方法 。 

(1) Shared Memory 协议 。 当 客户 端 与 SQL Server 数据 库 服务 器 位 于 同一 台 计 算 机 
上 时 ,使 用 这 种 网 络 协议 可 以 实现 两 者 间 的 通信 。 但 是 这 种 网 络 协议 无 法 为 网 络 中 的 两 台 
计算 机 间 提 供 SQL Server 服务 器 访问 。 默 认 情 况 下 ,该 协议 状态 被 设置 为 “已 启用 ”。 

配置 该 协议 时 ,双击 Shared Memory 选项 即 可 打开 “Shared Memory 属性 ”对 话 框 ,在 
该 对 话 框 中 用 户 可 以 启用 或 禁用 该 选项 ,如 图 16-21 所 示 。 


Shared Memory 尾 性 ? x 


Protocol 


日 General 


已 启用 
启用 或 等 用 此 服务 器 实例 的 Shared Memory 协议 


[| 


图 16-21 “Shared Memory 属性 ”对 话 框 


(2) Named Pipes 协议 。 该 协议 是 在 客户 端 与 服务 器 间 建 立 连接 时 ,不 需要 考虑 各 自 
使 用 的 网 络 协议 的 细节 ,而 直接 使 用 MSNP(Microsoft Network Provider) 重 定向 器 实现 两 
者 间 的 连接 。 因 此 启用 了 SQL Server 2016 数据 库 服务 器 上 的 Name Pipes 功能 ,那么 客户 
端 将 可 以 使 用 多 种 不 同 的 网 络 协议 。 当 在 与 服务 器 建立 连接 时 ,只 需 按照 命名 规则 提供 相 
应 的 路 径 名 即 可 以 直接 访问 SQL Server 数据 库 服务 器 。 


Named Pipes 协议 的 配置 工作 同样 十 分 简单 。 双 击 该 选项 ,打开 “Named Pipes 属性 ” 
对 话 框 ,在 该 对 话 框 中 可 以 指定 客户 用 于 访问 SQL Server 数据 库 服 务 器 时 使 用 的 管道 名 
称 ,以 及 启用 还 是 禁用 该 协议 ,如 图 16-22 所 示 。 


Named Pipes 尾 性 ? x 


Protocol 


日 General 


16-22 “Named Pipes 属性 ”对 话 框 


(3) TCP/IP 协议 。TCP/IP 协议 是 客户 端 用 于 访问 服务 器 的 标准 以 太 网 协议 。 即 通 
过 这 种 协议 ,客户 端 可 以 用 访问 某 一 IP 地 址 的 方式 访问 一 台 SQL Server 数据 库 服 务 器 , 显 
然 此 时 SQL Server 数据 库 服务 器 与 所 在 计算 机 的 IP 地 址 相 绑 定 。 由 于 TCP/IP 协议 本 身 
所 具有 的 安全 风险 ,默认 情况 下 该 协议 处 于 “禁用 ?状态 。 
与 前 面 两 个 协议 相 比较 ,使 用 最 为 广泛 的 TCP/IP 协议 的 配置 工作 要 相对 复杂 一 些 。 
双击 该 协议 选项 ,打开 “TCP/IP 属性 ?对 话 框 。 该 对 话 框 为 TCP/IP 的 属性 设置 提供 了 两 
类 配置 选项 , 即 与 协议 有 关 的 配置 选项 和 与 IP 地 址 相关 的 配置 选项 。 
@ 选择 “TCP/IP 属性 ?对 话 框 中 的 Protocol/( 协 议 ) 选 项 卡 ,如 图 16-23 所 示 。 
其 中 : 
。 保持 活动 状态 : 用 于 指定 TCP 检查 空闲 连接 是 否 仍 保持 活动 状态 。 
。 全 部 侦 听 : 用 于 指定 SQL Server 是 否 侦 听 所 有 与 计算 机 网 卡 相 绑 定 的 IP 地址。 如 
果 设 置 为 “ 否 ”, 则 使 用 每 个 IP 地 址 各 自 的 属性 对 话 框 对 各 个 IP 地 址 进行 配置 。 如 
果 设 置 为 “是 ”, 则 IP Addresses 选项 卡 中 All 属性 框 的 设置 将 应 用 于 所 有 的 IP 地 
址 。 默 认 情 况 下 该 值 被 设置 为 “是 ”。 

。 已 启用 : 该 项 是 否 启 用 。 

@ 选择 “TCP/IP 属性 ”对 话 框 中 的 IP Addresses 选项 卡 , 如 图 16-24 所 示 。 

其 中 ， 

。 JIP 地 址 : 用 于 查看 或 更 改 此 连接 使 用 的 IP 地 址 。 

。 TCP 动态 端口 : 用 于 在 建立 TCP 连接 时 使 用 动态 端口 。 如 果 想 要 启用 动态 端口 ， 
应 将 该 选项 设置 为 0。 
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日 General 
EE 
全 部 侦 听 是 
已 启用 是 

保持 活动 状态 

TCP 检查 补 亲 连接 是 否 仍 保持 原样 的 舌 杰 


16-23 ”Trotocol 选项 卡 


圈 Tcp/p 尾 性 


Protocol IP Addresses 


日 1 a 
旧地 直 fe80-14b8-e4c5-5cab:b8b4369 
TCP 动态 说 口 

TCP 车 口 1433 

活动 是 

已 启用 理 

日 pyo 

旧地 址 fe80-2c82.5fdd-3591-2e50%15 
TCP 动态 镇 口 

TcP 读 口 1433 

活动 是 

已 启用 否 

日 pz 

[ee 

TCP 动态 转口 v 
IP 地 址 

中 地 址 

Ce | NR 


图 16-24 IP Addresses 选项 卡 


。TCP 端口 : 如 果 决 定 启用 指定 的 端口 作为 建立 TCP 连接 的 侦 听 端口 ,可 以 在 “TCP 
端口 "选项 中 设置 该 端口 的 值 。 默 认 情 况 下 ,SQL Server 数据 库 服务 器 使 用 端口 


1433 作为 其 TCP 侦 听 端口 。 


。 活动 : 用 于 指示 所 选 的 IP 地 址 是 否 处 于 活动 状态 。 


"已 启用 : 该 项 是 否 启用 。 

SQL Server 配置 管理 器 会 自动 根据 当前 的 实际 情况 显示 连接 SQL Server 时 可 用 的 他 地 址 。 

如 果 发 生 以 下 情况 ,可 用 的 IP 地 址 也 会 随 之 改变 : 添加 或 删除 网 卡 动态 分 配 的 IP 地 
址 过 期 .重新 配置 网 络 结构 或 计算 机 的 物理 位 置 发 生 改变 (如 便携 式 计 算 机 在 另 一 座 大 楼 连 
接 到 网 络 ) 。 若 要 更 改 IP 地 址 ,可 以 编辑 “IP 地 址 ”文本 框 ,然后 重新 启动 SQL Server。 


16.3.2 配置 SQL Server 2016 服务 器 的 性 能 参数 


在 SQL Server 2016 中 管理 数据 库 性 能 相关 参数 的 方法 主要 有 两 种 : 一 种 是 通过 SQL 
Server Management Studio 对 相关 参数 进行 设置 , 另 一 种 则 是 利用 SQL Server 2016 提供 的 
系统 存储 过 程 sp_configure。 

利用 系统 存储 过 程 sp_configure 的 方式 可 以 在 “查询 编辑 器 ”窗口 中 输入 sp_configure， 
然后 单 击 “ 执 行 " 按 钮 ,该 存储 过 程 将 列 出 可 以 进行 设置 的 数据 库 服务 器 参数 和 它们 的 当前 
值 ,详细 内 容 可 以 通过 查看 联机 从 书 进行 了 解 。 

下 面 介 绍 如 何 使 用 SQL Server Management Studio 配置 服务 器 参数 。SQL Server 
Management Studio 为 管理 SQL Server 数据 库 服务 器 的 性 能 提供 相应 的 选项 ,使 用 该 工具 
进行 配置 的 步 又 如 下 。 

(1) 在 “对 象 资源 管理 器 ”中 右 击 需要 配置 的 数据 库 服 务 器 ,从 弹出 的 快捷 菜单 中 选择 
“属性 ”命令 ,打开 “服务 器 属性 ”窗口 。 该 窗口 中 提供 了 与 该 数据 库 服 务 器 相关 的 8 项 配置 
参数 ,本 示例 只 介绍 其 中 与 数据 库 运 行 性 能 相关 的 参数 。 

(2) 在 “服务 器 属性 "窗口 中 的 “选择 页 ”列表 框 中 选择 "内存" 选项 ,其 右 侧 的 选项 页 中 
给 出 了 与 SQL Server 数据 库 相 关 的 内 存 设 置 参 数 ,如 图 16-25 所 示 。 在 该 选项 中 ,数据 库 
管理 员 可 以 设置 以 下 参数 : 
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多 他 加 服务 器 内 存 选项 


办 相 限 最 小 服务 器 肉 存 06) 00 
p | 
最 大 服务 器 内 存 0m) (X) 
Pi 图 


其 他 内 存 寺 项 
创 当 案 引 占用 的 内 存 (2，0 ~ 动态 内 存 ) (1) 
p 图 
每 大 村 让 占 用 的 最 小 内 存 (D) (9) 


i 图 


图 16-25 “内 存 ” 选 项 卡 
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最 小 服务 器 内 存 : 该 参数 用 于 指定 启动 SQL Server 数据 库 服务 器 时 至 少 可 以 被 分 
配 的 最 小 内 存量 。 

最 大 服务 器 内 存 : 指定 启动 或 运行 SQL Server 数据 库 服务 器 时 可 以 分 配 的 内 存 最 
大 量 。 如 果 知 道 有 多 个 应 用 程序 与 SQL Server 同时 运行 ,并 且 要 保证 这 些 应 用 程 
序 有 足够 的 内 存 运 行 , 则 可 以 将 此 配置 选项 设置 为 指定 值 。 

创建 索引 占用 的 内 存 : 用 于 指定 在 索引 创建 排序 过 程 中 要 使 用 的 内 存量 。 默 认 值 
为 0, 表 示 启 用 动态 分 配 ,在 大 多 数 情况 下 不 需要 进一步 调整 即 可 正常 工作 。 不 过 ， 
用 户 可 以 根据 需要 输入 704 一 2 147 483 647 的 其 他 值 。 

每 次 查询 占用 的 最 小 内 存 : 用 于 为 执行 查询 操作 指定 需要 分 配 的 内 存量 。 用 户 可 
以 设置 512 一 2 147 483 647 的 值 ,默认 值 为 1024。 

配置 值 : 用 于 显示 上 述 参 数 的 当前 配置 值 。 如 果 根 据 需 要 更 改 了 上 述 参 数 的 当前 
值 ,可 选中 “运行 值 ” 单 选 按钮 ,以 查看 所 做 的 修改 是 否 已 经 生效 。 如 果 尚 未 生效 ,可 
尝试 重新 启动 SQL Server 实例 。 

运行 值 : 选中 “运行 值 ” 单 选 按 钮 ,可 以 查看 “内 存 ” 中 各 选项 的 当前 运行 值 。 这 些 值 
为 只 读 值 。 

(3) 选择 “处 理 器 ”选项 卡 。 管 理 员 可 以 根据 实际 情况 配置 SQL Server 可 以 使 用 的 
CPU( 如 果 SQL Server 2016 数据 所 在 的 计算 机 上 安装 了 多 个 CPU 的 话 ) ,设置 “最 大 工作 
线程 数 ”、 是 否 提 升 SQL Server 的 优先 级 以 及 是 否 使 用 Windows NT 纤 程 (轻型 池 ) 等 功 
能 ,如 图 16-26 所 示 。 其 中 各 参数 的 具体 含义 如 下 。 
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启用 处 理 器 
自动 设置 所 有 处 理 器 的 处 理 器 关联 接 码 (P) 
自动 设置 所 有 处 理 器 的 I/0 关联 搞 码 (I) 
[4 再 器 让 理 吕 关 联 
日 -全 部 


线程 
最 大 工作 线程 数 00 
图 
提升 SQL Server 的 优先 级 (B) 
口 使 用 Windows 纤 程 (轻型 地 ) (WD) 


@ 本 置信 () 


图 16-26 “处 理 器 ”选项 卡 


自动 设置 所 有 处 理 器 的 处 理 器 关联 掩 码 : SQL Server 2016 通过 关联 掩 码 (Affinity 
Mask) 选 项 来 提供 处 理 器 关联 。 关 联 掩 码 主要 用 于 动态 控制 CPU 关联 。 通 过 将 各 
处 理 器 分 配给 指定 线程 ,可 以 消除 处 理 器 的 重新 加 载 需求 并 减少 处 理 器 之 间 的 线程 
迁移 ,从 而 提高 SQL Server 性 能 。 线 程 与 处 理 器 之 间 的 这 种 关联 称 为 “处 理 器 
关联 :5 
自动 设置 所 有 处 理 器 的 I/O 关联 掩 码 : 除了 关联 掩 码 之 外 ,SQL Server 2016 还 提 
供 了 名 为 IO 关联 掩 码 的 选项 来 实现 处 理 器 关联 。L/O 关联 掩 码 选项 将 SQL 
Server 磁盘 1/O 与 指定 的 CPU 子 集 绑 定 。 在 高 端 SQL Server 联机 事务 处 理 (On- 
Line Transaction Processing,OLTP) 环 境 中 ,此 扩展 可 以 提高 SQL Server 线程 执 
行 1/O 的 性 能 。 此 增强 功能 不 支持 对 各 个 磁盘 或 磁盘 控制 器 的 硬件 关联 。 
最 大 工作 线程 数 : 如 果 为 0, 则 允许 SQL Server 动态 设置 工作 线程 数 。 对 于 大 多 数 
系统 而 言 , 此 为 最 佳 设 置 。 当 然 , 数 据 库 管理 员 也 可 以 根据 自己 的 系统 配置 设置 指 
定 的 值 以 提高 SQL Server 的 性 能 。 
提升 SQL Server 的 优先 级 : 指定 SQL Server 是 否 能 够 以 比 计 算 机 上 其 他 进程 更 高 
的 优先 级 运行 。 

。 使 用 Windows 纤 程 (轻型 池 ): 使 用 Windows 纤 程 代替 SQL Server 服务 的 线程 。 

需要 注意 的 是 ,此 选项 仅 适用 于 Windows 2003 Server Edition 。 

(4) 选择 “连接 ?选项 卡 。 该 选择 卡 中 提供 了 与 用 户 连接 有 关 的 许多 设置 ,如 图 16-27 
所 示 。 其 中 主要 的 参数 如 下 。 
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过 接 
最 大 并 发 连 按 糙 (= 无 限制) 0); 
p 各 
口 人 用 查 局 吕 防 止 查询 长 时 间 运 行 () 
PE 
这 扩 和 项): 


DD inlet tsactions 
口 :esor elose on commit 
口 msi warnings 

口 msi paddine 

日 Asr mus 

口 ithmetie abort 


运程 有 务 器 演 接 
回 允许 远程 放 接 到 此 服务 器 () 
运程 查询 超时 值 秒 ,0 = 无 超时 ) (9) 
色 图 

口 需要 将 分 布 式 事务 用 于 服务 器 到 服务 器 的 通信 (BE) 


加 配置 值 C) 〇 运行 值 (8) 


图 16-27 “连接 ?选项 卡 


人 妥 装 和 配置 SQL Server 2016 


SQL Server 2016 数据 亩 应 用 与 开发 习题 解答 与 上 志 指 时 


。 最 大 并 发 连接 数 : 将 该 选项 设置 为 非 零 值 , 即 可 限制 与 Microsoft SQL Server 建立 
连接 的 数目 。 

。 使 用 查询 调控 器 防止 查询 长 时 间 和 运行 : 为 该 选项 设置 相应 的 值 ,可 以 有 效 地 避免 由 
于 长 时 间 查 询 操作 而 造成 的 SQL Server 没有 响应 现象 。 

。 默认 连接 选项 : 可 以 规定 与 SQL Server 2016 建立 连接 后 所 具有 的 相关 特性 。 例 
如 ,xact abort 选项 表示 如 果 Transact-SQL 语句 引发 运行 时 错误 , 则 回 滚 事务 。 

。 选项 允许 远程 连接 到 此 服务 器 : 如 果 和 希望 通过 远程 连接 的 方式 连接 SQL Server 
2016 数据 库 服务 器 , 则 需要 选中 该 复 选 框 。 除 此 之 外 ,管理 员 还 可 以 根据 需要 设置 
远程 查询 的 超时 值 , 以 避免 长 时 间 等 待 的 情况 发 生 。 

。 需要 将 分 布 式 事务 用 于 服务 器 到 服务 器 的 通信 : 通过 Microsoft 分 布 式 事务 处 理 协 
调 器 (MS DTC) 事 务 保护 服务 器 到 服务 器 过 程 的 操作 ,可 以 强制 将 分 布 式 事务 用 于 
远程 过 程 。 

(5) 选择 “高 级 ”选项 卡 。 可 在 其 中 查看 或 修改 高 级 服务 器 的 设置 ,如 图 16-28 所 示 。 

其 中 主要 的 参数 如 下 。 
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图 16-28 查看 或 修改 高 级 服务 器 的 设置 


Q@ FILESTREAM 选项 中 包含 的 选项 : 

。 FILESTREAM 访问 级 别 :显示 SQL Server 实例 上 支持 的 FILESTREAM 的 当前 
级 别 。 已 禁用 (默认 值 ) .已 启用 Transact-SQL 访问 和 已 启用 完全 访问 。 

。 FILESTREAM 共享 名 :显示 在 安装 过 程 中 选择 的 FILESTREAM 共享 只 读 名 称 。 

@@ “包含 ”选项 中 的 设置 项 :启用 包含 的 数据 库 , 用 于 管理 独立 于 其 他 数据 库 以 及 承载 数 


据 库 的 SQL Server/SQL Database 实例 和 master 数据 库 之 外 的 数据 库 的 选项 ,默认 值 为 False。 
@@“ 并 行 ” 选 项 中 包括 的 设置 项 : 
。 并 行 的 开销 阔 值 : 指定 冰 值 ,在 高 于 该 国 值 时 ,SQL Server 将 创建 并 运行 查询 并 行 
计划 。 
。 查询 等 待 值 : 指定 在 超时 之 前 查询 等 待 资源 的 秒 数 。 该 选项 为 一 1 时 , 则 按 估计 查 
询 开 销 的 25 倍 计算 超时 值 。 
。 锁 : 设置 可 用 锁 的 最 大 数目 ,以 限制 SQL Server 为 锁 分 配 的 内 存量 。 默 认 设置 为 
0, 即 允许 SQL Server 根据 不 断 变化 的 系统 要 求 动态 地 分 配 和 释放 锁 。 
。 最 大 并 行 度 : 限制 执行 并 行 计划 时 所 使 用 的 处 理 器 数 ( 最 多 为 64 个 )。 如 果 默 认 值 
为 0, 则 使 用 所 有 可 用 的 处 理 器 。 
@@ “网络 ”选项 中 包括 的 设置 项 : 
。 网 络 数据 包 大 小 : 设置 整个 网 络 使 用 的 数据 包 大 小 。 默 认 数 据 包 大 小 为 4096 个 字 节 。 
。 远程 登录 超时 值 : 指定 从 远程 登录 尝试 失败 返回 之 前 SQL Server 等 待 的 秒 数 。 默 
认 值 为 20s。 如 果 将 该 选项 的 值 设 置 为 0, 则 表示 允许 无 限期 等 待 。 
@@“ 杂 项 ”选项 中 包括 的 设置 项 : 
。 两 位 数 年 份 截止 : 用 于 设置 可 以 用 两 位 数 表示 的 最 大 年 份 。 
。 默认 全 文 语言 : 指定 全 文 索引 列 的 默认 语言 。 
。 默认 语言 : SQL Server 2016 数据 库 服 务 器 使 用 的 语言 。 
。 启动 时 扫描 存储 过 程 : 指定 SQL Server 将 在 启动 时 扫描 ,并 自动 执行 存储 过 程 。 
游标 国 值 : 指定 游标 集中 的 行 数 , 若 超过 此 行 数 ,将 异步 生成 游标 键 集 ,从 而 使 用 户 
能 够 在 继续 填充 游标 的 同时 从 该 游标 中 提取 行 。 否 则 ,同步 生成 游标 ,查询 将 一 直 
等 待 到 返回 所 有 行 。 
。 最 大 文本 复制 大 小 : 指定 用 一 个 INSERT、UPDATE 、WRITETEXT 或 UPDATETEXT 
语句 可 以 向 复制 列 添加 的 text 和 image 数据 的 最 大 大 小 ( 字 节 )。 
除了 上 述 介绍 的 4 个 选择 卡 之 外 ,“ 服 务 器 属性 ”窗口 中 还 提供 了 “常规 “安全 性 “数据 
库 设置 "和 “权限 ”4 个 选项 卡 , 相 关内 容 在 此 不 再 袭 述 。 


16.3.3 配置 远程 服务 器 


SQL Server 2016 提供 的 远程 服务 器 功能 使 得 客户 端 可 以 通过 网 络 访问 指定 的 SQL 
Server 服务 器 ,以 便 在 没有 建立 单独 的 连接 的 情况 下 在 其 他 SQL Server 实例 上 执行 存储 过 
程 。 此 时 客户 端 所 连接 的 服务 器 接受 客户 端的 请 求 , 并 代表 客户 端 将 该 请 求 发 送 到 远程 服 
务 器 。 远 程 服务 器 处 理 请 求 , 并 将 所 有 结果 返回 到 原始 的 服务 器 ,服务 器 再 将 那些 结果 传递 
给 客户 端 。 当 设置 远程 服务 器 配置 时 ,还 应 考虑 如 何 建 立 安全 性 。 

通常 远程 服务 器 是 成 对 设置 的 ,即将 关联 的 两 台数 据 库 服务 器 配置 为 彼此 可 以 相互 识 
别 的 远程 服务 器 。 大 多 数 情 况 下 ,用 户 不 需要 手动 配置 选项 来 设置 远程 服务 器 。SQL 
Server 2016 本 地 计算 机 和 远程 计算 机 的 默认 配置 将 自动 支持 远程 服务 器 连接 。 

为 了 能 够 进行 远程 访问 ,必须 在 本 地 和 远程 计算 机 上 将 远程 访问 (Remote Access) 配 置 
选项 设置 为 1( 默 认 设置 )。 远 程 访问 控制 远程 服务 器 的 登录 ,可 以 通过 使 用 sp_configure 
存储 过 程 或 SQL Server Management Studio 重 置 此 配置 选项 。 
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1. 使 用 SQL Server Management Studio 启用 远程 连接 功能 

启用 远程 连接 功能 的 具体 步骤 如 下 。 

(1) 启动 SQL Server Management Studio , 右 击 数据 库 服务 器 ,从 弹出 的 快捷 菜单 中 选 
择 “ 属 性 ”命令 ,在 打开 的 “服务 器 属性 ”对 话 框 中 选择 “连接 ”选项 卡 , 选 中 右 侧 的 “连接 ”选项 
卡 中 的 “允许 远程 连接 到 此 服务 器 ” 复 选 框 , 即 可 启用 该 数据 库 服务 器 的 远程 连接 功能 ,如 
图 16-27 所 示 。 

(2) 通过 SQL Server 2016 提供 的 系统 存储 过 程 sp_configure 来 启动 远程 连接 功能 。 
新 建 一 个 “查询 编辑 器 ”窗口 ,然后 在 其 窗口 中 输入 下 面 的 Transact-SQL 脚本 代码 : 

EXEC sp_configure ‘'remote access'， 1 

RECONFIGURE 

G0 

单 击 “ 执 行 ” 按 钮 ,运行 结果 将 显示 :“ 配 置 选 项 'remote access' 已 从 0 更 改 为 1。 请 运行 
RECONFIGURE 语句 进行 安装 ”。 

相反 ,如 果 和 希望 禁用 远程 服务 器 配置 ,以 防止 用 户 访问 本 地 服务 器 ,可 以 采取 相反 的 措 
施 进行 设置 。 

2. 连接 远程 服务 器 

在 按照 上 述 介绍 的 内 容 正确 地 配置 好 服务 器 的 远程 连接 选项 后 ,可 以 尝试 使 用 SQL 
Server Management Studio 来 连接 远程 服务 器 ,具体 步骤 如 下 。 

(1) 启动 SQL Server Management Studio ,在 其 “连接 到 服务 器 ”对话 框 中 的 “服务 器 名 
称 ” 文 本 框 中 输入 相应 连接 的 远程 服务 器 的 IP 地 址 ,以 及 该 SQL Server 服务 器 用 于 侦 听 的 
端口 号 (默认 端口 为 1433) 。 

(2) 分 别 在 “登录 名 ”和 “密码 "文本 框 中 输入 需要 登录 的 数据 库 服 务 器 的 登录 账号 及 对 
应 的 密码 (本 示例 使 用 sa 账号 登录 远程 数据 库 服务 器 ,但 实际 使 用 中 最 好 在 远程 数据 库 服 
务 器 上 为 远程 登录 配置 专门 的 登录 名 和 密码 ) ,如 图 16-29 所 示 。 


SQL Server 
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192. 168. 1. 108:1433 


SQL Server 身份 验证 


sa 
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图 16-29 “连接 到 服务 器 对话 框 


(3) 单 击 “ 连 接 ? 按 钮 即 可 登录 指定 的 远程 数据 库 服 务 器 。 一 旦 成 功 登 录 远 程 数据 库 服 
务 器 , 即 可 以 像 浏览 本 地 数据 库 服 务 器 一 样 ,通过 SQL Server Management Studio 来 访问 
远程 数据 库 服务 器 。 

还 可 以 通过 查询 相关 资料 进行 配置 和 使 用 ,在 此 不 再 袭 述 。 
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SQL Server 2016 Management Studio( 管 理 平台 ) 是 为 SQL Server 数据 库 管 理 员 和 开 
发 人 员 提 供 的 新 工具 , 它 提 供 了 用 于 数据 库 管理 的 图 形 工 具 和 功能 丰富 的 开发 环境 。 在 此 
环境 下 ,熟悉 对 象 资源 管理 器 .菜单 栏 .工具 栏 .查询 编辑 器 、 模 板 资源 管理 器 等 工具 的 基本 
操作 是 学 习 和 掌握 SQL Server 2016 数据 库 的 基础 和 关键 。 本 章 将 从 初学 者 的 角度 介绍 这 
些 工 具 的 使 用 方法 ,以 及 编写 和 调试 Transact-SQL 脚本 代码 时 应 该 注意 的 问题 。 


17.1 SQL Server 2016 的 管理 平台 的 使 用 


在 正确 安装 完成 SQL Server 2016 系统 后 ,就 可 以 启动 SQL Server 2016 Management 
Studio, 进 入 如 图 17-1 所 示 的 SQL Server Management Studio 窗口 ,窗口 中 主要 包括 以 下 
几 方 面 的 内 容 。 


山 SQLQvery1.sql teaching (LG37CEYPE9YWCSG\ 


- BE 
日 了 BLG37CEYPE9YWCSG (SQL Server 13. 


田 国 AlwaysOn 高 可 用 性 加 Certificate 
田园 管理 田 Change Data Capture 
田 各 Integration Services 目录 回访 Change Tracking 
田 七 SQL Server 代理 田 筷 Credential 
田 向 Database 
轩 园 Database Mail 
田 国 Database Role 
田园 Database Trigger 
田 国 Defauk 
田 国 Earier Versions 


图 17-1 Management Studio 初始 界面 


(1) 标题 栏 。 标 题 栏 位 于 该 集成 环境 的 第 一 行 。 标 题 栏 最 左 侧 是 控制 图 标 ,还 有 集成 
环境 名 (Microsoft SQL Server Management Studio) 和 窗口 的 关闭 、 最 大 化 (还 原 )、 最 小 化 
图 标 。 控 制图 标 主要 包括 窗口 的 还 原 、 移 动 \ 大 小 .最 大 化 .最 小 化 .关闭 等 简单 菜单 命令 。 
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单 击 窗口 关闭 图 标 可 以 关闭 该 窗口 。 在 窗口 边缘 上 拖 动 可 以 缩放 窗口 。 

(2) 主 菜单 栏 。 从 图 17-1 可 以 看 到 ,集成 环境 的 第 二 行为 主 菜单 ,其 中 常见 的 菜单 项 
有 文件 .编辑 .视图 查询、 项 目 . 调 试 .工具 ,窗口 、 帮 助 等 。 用 鼠标 可 以 选择 主 菜单 条 中 所 需 
要 的 菜单 项 , 单 击 此 菜单 项 就 会 出 现 一 个 下 拉 菜 单 。 另 外 ,当前 执行 某 项 操作 时 , 主 菜单 也 
会 随 之 添加 新 菜单 项 ,如 单 击 “ 新 建 查询 ”按钮 ,系统 会 自动 在 “视图 ”之 后 添加 “查询 ”和 “项 
目 ” 菜 单项 。 

(3) 工具 栏 。 菜 单 栏 的 下 面 是 工具 栏 。 工 具 栏 主要 是 将 一 些 常用 的 操作 图 形 化 ,如 “新 
建 查询 “打开 文件 ”等 功能 。 只 要 单 击 某 个 图 标 ,就 可 以 让 系统 执行 相应 的 操作 。 

(4)“ 已 注册 的 服务 器 ”窗口 。 列 出 经 常 管理 的 服务 器 ,也 可 在 此 窗口 中 添加 或 删除 服 
务 器 。 选 择 “ 视 图 ”>“ 已 注册 的 服务 器 "命令 ,可 以 对 该 窗口 进行 显示 和 隐藏。 

(5)“ 对 象 资源 管理 器 ”窗口 。 主 窗 体 左 侧 是 “对 象 资源 管理 器 ”窗口 ,该 窗口 将 所 有 已 
经 连接 的 数据 库 服 务 器 及 其 对 象 以 树 状 结构 显示 。 查 看 或 操作 时 ,只 要 单 击 选项 前 面 的 
“十 ”号 就 可 以 展开 其 包含 的 对 象 ,如 图 17-2 所 示 。 


日 图 L637CEYPE9YWCSG (SQL Server 13.0.200 - LG37CEYPE9YWCSGWdministraton) 
日 往 数据 库 
田 国 系统 数据 库 
田 向 数据 库 快照 
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田 国 SQL Server 代理 


17-2 “对 象 资源 管理 器 "窗口 


若 在 SQL Server Management Studio 环境 内 没有 看 到 “对 象 资 源 管理 器 "窗口 ,可 以 通 
过 选择 “视图 ”>“ 对 象 资源 管理 器 ”命令 打开 该 窗口 。 

(6)“ 文 档 ” 窗 口 。 该 区 域 采用 选项 卡 的 方式 实现 多 项 功能 。 在 默认 情况 下 显示 空白 
页 。SQL Server Management Studio 的 文档 窗口 主要 用 于 SQL 语句 脚本 的 编写 、 表 的 创 
建 . 数 据 表 的 展示 和 报表 展示 等 。 例 如 , 单 击 “新 建 查询 ”按钮 ,输入 一 个 SQL 语句 , 则 “ 文 
档 ” 窗 口 变 成 如 图 17-3 所 示 的 状态 。 同 时 可 以 观察 到 主 菜单 和 工具 栏 也 发 生 了 变化 。 

(7) 属性 窗口 。 主 窗 体 的 右 侧 可 以 是 属性 窗口 ,主要 用 于 查看 ,修改 对 象 的 属性 。 

(8)“ 模 板 浏览 器 ”窗口 。 主 窗 体 右 侧 也 可 以 显示 “模板 浏览 器 "窗口 ,主要 用 于 查看 和 
调用 模板 等 操作 。 有 时 属性 区 域 与 模板 浏览 器 区 域 自动 隐藏 到 窗口 最 右 侧 ,用 鼠标 移动 到 
属性 选项 卡 上 则 其 会 自动 显示 出 来 。 

SQL Server Management Studio 附带 了 用 于 许多 常见 任务 的 模板 ,模板 的 真正 作用 在 


Bm sqlex717.sql - LG37CEYPE9YWCSG4eaching (LG37CEYPE9YWCSGWdministrator (52)) - Microsoft SQL Server Manage.. — DO Xx 


sqlex 717.sql - LG..dministrator (62)) Xx - 
一 例 7. 17 查 询 student 表 中 是 否 存 在 在 1999 年 12 月 12 日 以 局 
BSELECT studentno, sname, birthdate, phone 
FROM student 
WHERE EXISTS ( 
田 国 ReportServer SELECT * 
加 国 ReportServerTempDB FROM student 


WHERE birthdate < ’ 1999-12-12” ) 


eo birthdste phone 
pr 
[L7133071 | 状 洗 坚 1996-06-06 15556645645 
2 17112100072 。” 窒 臻 远 1999-02-04 12545676998 
田 国 Integration Services 目录 v 量 -= 一 一 二 二 
y 园 二 .LG37CEYPE9YWCSG (13.0 CTP) LG37CEYPE9YWCSG\Admini.。teaching 00:00:00 13 行 


图 17-3 “文档 ”窗口 


于 它 能 为 必须 频繁 创建 的 复杂 脚本 创建 自 定义 模板 。 这 些 模 板 是 包含 必要 表达 式 的 基本 结 
构 的 文件 ,以 便 在 数据 库 中 新 建 对 象 。 

通过 选择 主 菜单 栏 中 的 “视图 ”一 “模板 浏览 器 "命令 打开 “模板 浏览 器 "窗口 。 若 要 查看 
不 同类 型 服务 的 语法 模板 ,可 以 通过 “模板 浏览 器 "窗口 最 上 方 的 工具 行 切换 两 种 不 同 的 语 
法 模板 : SQL Server 模板 和 Analysis Services 模板 。 

若 不 熟悉 如 何 通过 相关 语言 完成 某 项 任务 ,可 以 查找 预先 提供 的 模板 ,通过 修改 部 分 内 
容 来 完成 任务 。 

SQL Server 2016 提供 了 很 丰富 的 各 种 模板 ,模板 的 原始 定义 位 于 Windows 登录 账号 
的 Documents and Settings 文件 夹 下 的 Application Data\Microsoft\Microsoft SQL Server\100 \ 
Tools\Shell \Templates 目录 内 。 解 决 方案 ,项 目 和 各 类 型 的 程序 代码 编辑 环境 都 可 以 使 用 
模板 。 

利用 模板 创建 数据 库 .数据 表 、 视 图 .索引 、 存 储 过 程 、. 触 发 器 、 统 计数 据 和 函数 等 对 象 ， 
还 有 一 些 模板 可 创建 Analysis Services 和 SQL Server Compact Edition 的 扩充 属性 .连接 
服务 器 ,登录 ,角色 ,用 户 等 。 例 如 ,为 表 添 加 行 的 SQL Server Compact Edition 模板 代码 如 
图 17-4 所 示 。 

另外 ,在 各 窗 体 中 的 不 同 对 象 上 右 击 ,还 可 以 随时 进行 弹出 菜单 中 规划 好 的 操作 。 在 学 
习 过 程 中 通过 不 断 的 练习 ,逐步 掌握 其 中 的 重要 操作 。 

SQL Server Management Studio 是 一 个 功能 强大 且 灵 活 的 工具 ,了 解 如 何 清除 不 需要 
的 窗口 ,快速 访问 包含 所 需 信息 的 窗口 .更改 环境 布局 、 与 已 注册 的 服务 器 和 对 象 资源 管理 
器 连接 、 配 置 默认 界面 等 操作 是 学 习 SQL Server 2016 的 基本 要 求 。 

可 以 使 用 SQL Server Management Studio 作为 SQL Server、Analysis Services 和 SQL 
Server Mobile 的 脚本 开发 平台 。 使 用 SQL Server Management Studio 可 以 为 关系 数据 库 
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SQLQuery2.sql - L.dministrator (5D)”X 


日 CREATE TABLE “schema name! 
a( 回国 Statistics 


i Stored proced 

columnl int NOT 本 

~ i ynonym 

colum2 char (10) NULL 日 Table 

国 Add Column 

国 Add Constraint 

人 Add Flestream Col 

一 Add a new column to th -rs ee 

BALTER TABLE 《schema name, 国 Add Memory Optimized Column 
ADD <new_column_name, 全 Add Memory Optimized Constraint 

国 Add Memory Optimized Hash Index 
国 Add Memory Optimized Key 


ET ro- 


图 17-4 “模板 浏览 器 ”的 使 用 


和 多 维 数据 库 以 及 所 有 查询 类 型 开发 脚本 。 具 体 来 说 ,使 用 SQL Server Management 
Studio 可 以 实现 如 下 功能 : 

(1) 编写 查询 和 脚本 以 支持 生产 过 程 。 

(2) 将 连接 信息 和 其 他 关联 文件 添加 到 项 目 中 。 

(3) 将 查询 和 脚本 及 其 连接 保存 在 项 目 中 。 

(4) 将 脚本 项 目 组 织 在 称 为 “解决 方案 ”的 单个 容器 中 。 

(5) 将 解决 方案 保存 在 Microsoft Visual Source Safe (VSS) 数 据 库 或 其 他 第 三 方 源 代 
码 管 理 提供 程序 中 ,以 进行 开发 ,更改 . 跟 踪 和 生存 周期 管理 。 


17.2 SQL Server 2016 菜单 的 使 用 


进入 SQL Server Management Studio 集成 环境 后 ,可 以 通过 以 下 三 种 方式 访问 主 菜单 
下 的 下 拉 菜 单 。 

@ 利用 鼠标 单 击 菜单 项 。 

@ 按 Alt 键 加 上 某 菜 单项 中 第 一 个 字母 ( 即 大 写字 母 ) 。 

@ 按 Fl10 键 后 ,再 通过 按 移动 光标 键 和 回 车 键 ,就 可 进入 下 拉 菜 单 中 。 

下 面 对 SQL Server 2016 的 主要 下 拉 菜 单 的 使 用 进行 简单 的 介绍 。 
17.2.1 常用 菜单 功能 

1.“ 文 件 ” 菜 单 

“文件 ”菜单 中 的 选项 用 于 支持 文件 管理 。 首 次 打开 SQL Server Management Studio 
时 ,在 创建 新 的 文件 (项 目 ) 或 打开 某 个 现 有 文件 (项 目 ) 之 前 . 某 些 菜单 选项 将 不 可 用 。 仅 当 
开始 在 某 个 解决 方案 上 下 文中 工作 或 打开 某 个 解决 方案 中 的 项 目 后 ,这 些 选 项 才 变 得 可 用 。 

“文件 ”菜单 主要 包括 如 图 17-5 所 示 下 拉 菜 单 中 的 各 选项 。 各 下 拉 菜 单项 的 功能 和 作 
用 如 下 : 

(1) 连接 对 象 资 源 管理 器 : 用 于 连接 指定 的 实例 。 


17-5 “文件 ?下拉 菜单 


(2) 断 开 与 对 象 资源 管理 器 的 连接 : 用 于 断 开 指定 的 实例 。 

(3) 新 建 : 用 于 建立 新 的 项 目 或 各 种 查询 文件 。 

(4) 打开 : 用 于 打开 项 目 或 文件 。 

(5) 添加 : 用 于 新 建 或 添加 项 目 。 例 如 选择 “新 建 项 目 ”, 则 会 弹出 如 图 17-6 所 示 的 对 
话 框 ,然后 根据 设置 的 参数 创建 新 项 目 。 


添加 新 项 目 时 x 


类 型 : SQL Server Management Studio 
用 于 创建 和 维护 SQL Server 项 的 项 目 。 


SQL Server 脚本 1 
CAUsers\Administrator\Documents\SQL Server Management ~ 


图 17-6 添加 新 项 目 


(6) 关闭 : 关闭 当前 正在 编辑 的 文件 。 第 
(7) 关闭 解决 方案 : 可 以 将 当前 解决 方案 从 “解决 方案 资源 管理 器 ”中 删除 。 亿 
章 
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(8) 保存 : 将 当前 进行 的 任务 或 作业 进行 保存 。 

(9) 另存 为 : 将 当前 进行 的 任务 或 作业 另外 保存 到 指定 文件 夹 或 文件 。 

(10) 全 部 保存 : 保存 现 有 的 所 有 项 目 或 文件 。 

(11) 页 面 设置 : 对 当前 文件 在 打印 之 前 进行 页 面 设置 。 

(12) 打印 : 打印 当前 文件 。 

(13) 最 近 使 用 文件 : 列 出 最 近 使 用 的 文件 清单 。 

(14) 最 近 使 用 项 目 : 列 出 最 近 使 用 的 项 目 清单 。 

(15) 退出 : 退出 SQL Server Management Studio 环境 。 

2.“ 编 辑 " 菜 单 

“编辑 ”菜单 中 的 选项 支持 对 文件 中 的 文本 和 代码 进行 编辑 。 此 菜单 提供 “撤销 ”和 “ 重 
复 ” 等 命令 ; 可 查找 和 替换 字符 串 和 符号 ,定位 到 代码 中 的 特定 行 号 ; 可 启用 和 管理 书签 。 
首次 打开 SQL Server Management Studio 时 ,在 创建 新 的 项 目 或 打开 某 个 现 有 项 目 之 前 ， 
某 些 选 项 不 可 用 。 当 项 目 开 始 或 文件 打开 后 , 某 些 选项 才 变 得 可 用 。 

“编辑 "菜单 主要 包括 如 图 17-7 所 示 下 拉 菜 单 中 的 各 选项 。 各 下 拉 菜 单项 的 功能 与 一 
般 的 Windows 窗 体 编辑 功能 相近 ,主要 操作 有 撤销 、 重 做 、 剪 切 、 复 制 、. 粘 贴 \ 删 除 、 全 选 、 查 
找 和 替换 等 ,在 此 不 再 著述 。 


LG37CEYPE9YWCSGWwdministraton) 


17-7 “编辑 ”菜单 


3.“ 视 图 "菜单 

“视图 ”菜单 中 的 选项 主要 用 于 管理 SQL Server Management Studio 的 用 户 界 面 。 此 
菜单 及 其 子 菜单 提供 打开 各 种 窗口 .工具 箱 、 资 源 管理 器 ,工具 栏 和 浏览 器 的 选项 ,具有 导航 
作用 。 

“视图 ”菜单 主要 包括 如 图 17-8 所 示 下 拉 菜 单 中 的 各 选项 。 常 用 下 拉 菜 单项 的 功能 和 
作用 如 下 : 

(1) 对 象 资源 管理 器 : 打开 “对 象 资源 管理 器 ”等 窗口 。 

(2) 工具 箱 : 打开 “工具 箱 ” 窗 口 。 

(3) 工具 栏 : 用 于 设置 “工具 栏 ” 的 状态 。 具 体操 作为 : 选择 “视图 ”一 “工具 栏 ” 命 令 ,在 
弹出 的 快捷 菜单 中 选择 相应 的 工具 栏 进 行 显示 或 隐藏 。 如 选择 “SQL 编辑 器 ”, 则 “SQL 编 
辑 器 ”工具 栏 就 会 在 SQL Server Management Studio 的 用 户 界 面 中 显示 ,如 图 17-9 所 示 。 


图 17-8 “视图 ”菜单 17-9 “工具 栏 ”快捷 菜单 


4.“ 工 具 ” 菜 单 

“工具 ”菜单 中 的 选项 可 用 于 自 定义 开发 环境 的 行 
为 。 如 图 17-10 所 示 , “工具 ”菜单 各 项 的 功能 和 作用 
如 下 。 

(1) SQL Server Profiler: 创建 跟踪 ,用 于 监视 
SQL Server 的 性 能 。 

(2) 数据 库 引 擎 优化 顾问 : 分 析 工 作 负 荷 ,提供 对 
数据 库 和 查询 进行 优化 的 工具 。 

(3) 选择 工具 箱 项 : 选择 要 在 “选择 工具 箱 项 ”对 
话 框 中 显示 的 项 ,如 图 17-11 所 示 。 

(4) 外 部 工具 : 选择 要 包括 在 环境 中 的 外 部 工具 。 
如 果 安 装 了 外 接 程 序 , 则 选择 要 包括 在 环境 中 的 外 接 程序 。 

(5) 自 定义 : 导入 和 导出 特定 环境 设置 ,或 将 环境 设置 重 置 为 其 默认 值 。 选 择 要 在 用 
户 界面 上 显示 的 工具 栏 , 并 排列 命令 的 顺序 ,如 图 17-12 所 示 。 

(6) 选项 : 设置 应 用 于 总 体 开发 环境 、 解 决 方案 和 项 目 、 源 代码 管理 \ 调 试 、 设 计 器 和 编 
辑 器 的 选项 。 选 择 用 于 调试 的 进程 和 代码 类 型 ,还 可 选择 自动 检测 代码 类 型 这 一 选项 ,如 


图 17-10 “工具 ”菜单 


图 17-13 所 示 。 
例如 ,要 改变 工作 区 中 内 容 的 字体 和 颜色 ,就 可 以 选择 “工具 ”>“ 选 项 "命令 ,在 弹出 的 第 
对 话 框 中 选择 “字体 和 颜色 ”进行 字体 和 颜色 的 设置 即 可 。 17 
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CAProgram Files (.. Microsoft.SqlServer.Management.Data... 
CNProgram Files (.. Microsoft'SqlServer.Management.Data... 
CAProgram Files (.. Microsoft. SqlServer.Management.Data... 
CNProgram Files (.. Microsoft SqlServer,Management.Data... 
CAProgram Files (.. Microsoft. SqlServer.Management.Data... 
“通知 操作 员 " 任 务 。。 CA\Program Files (.…。 MicrosoftSqlServer.Management.Data... 
“执行 SQL Server .。 Ci\Program Files (MicrosoftsqlserverManagementData- 
"执行 T-SQL 语句"…。 CNProgram Files (- sof SqlServer.,Management.Data... 
“重新 生成 索引 "任务 。 CA\Program Files (-. Microsoft.SqlServer.Management.Data... 
“重新 组 织 素 引 "任务 。 Ci\Program Files (.。 Microsoft'SqlServer,Management.Data... 


17-11 “选择 工具 箱 项 ”对 话 框 


17-12 “ 自 定义 ”对 话 框 


远大 ? Xx 
~ 环境 最 的 文件 

种 规 10 |" 窗口 "菜单 中 显示 的 项 (W) 

Web 济 攻 路 

埋 找 和 划拨 10 | 最 丘 使 用 的 文件 列表 中 显示 的 项 (R) 

导入 和 有 导出 设 秆 

》 铅 盘 视 党 体验 

二 [SE 

5 局 用 主语 客户 詹 视 区 体验 (E) 

i 如果 可 用 ， 请 使 用 硬件 轩 加 于 (U) 

i Visual studio 当前 正在 使 用 村 件 加 加 旦 现 . 视 党 体验 设置 检 后 动 基于 系统 功能 进行 
》 源 代码 管理 
》 文 相思 名 器 
》 查询 执行 
》 查询 结果 回 显示 状 志 栏 
>》 设计 各 回 关闭- 按 盘 只 影响 活动 工具 窗口 (O) 
》 SQL Server AlwaysOn 口 自动 耻 二 -过 得 只 影响 笑 动工 具 窗口 HH) 
》 SQL Server 对 象 资源 管理 严 还 原文 件 关联 们 ] 

[1[ 喜 


17-13 “选项 ”对 话 框 


5.“ 窗 口 " 菜 单 
“窗口 "菜单 中 的 选项 可 用 于 管理 SQL Server Management Studio 中 的 窗口 .资源 管理 
器 和 浏览 器 的 行为 ,如 图 17-14 所 示 。 


VY 1sQlauenaeql -LGa7cEYpEoY-PEoWcsGVdminiator 
OW- 


17-14 “窗口 "菜单 


例如 ,可 以 指定 窗口 是 浮动 的 还 是 可 停靠 的 .是 显示 为 选项 卡 式 文档 还 是 隐藏 。 打 开 的 
窗口 不 同 ,“ 窗 口 "菜单 包含 的 选项 也 可 能 不 同 。 
6.“ 帮 助 "菜单 
通过 “帮助 "菜单 可 以 几 种 不 同 的 途径 提供 有 关 SQL Server 的 信息 ,提供 对 以 前 无 法 在 
“帮助 ”环境 中 使 用 的 SQL Server 社区 项 目 、 示 例 和 MSDN 在 线 资源 的 访问 。 此 外 ,还 可 以 
将 “帮助 ”环境 配置 为 在 SQL Server Management Studio 环境 中 启动 或 在 其 自身 的 关联 外 
部 窗口 中 启动 ,如 图 17-15 所 示 。 
7.“ 查 询 ”菜单 
打开 查询 编辑 器 时 ,SQL Server Management Studio 环境 中 的 菜单 栏 中 就 会 出 现 “ 查 章 
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图 17-15 “帮助 ”菜单 
询 ” 菜 单 ,如 图 17-16 所 示 。 各 下 拉 菜 单项 的 功能 和 作用 如 下 : 


连接 (OQ » 
在 对 象 资源 管理 器 中 打开 了 服务 器 (O) Alt+F8 
全 措 症 模板 参数 的 值 (S).- Ctrl+Shift+M 
? 执行 00 5 
加 。 取 少 执行 查询 (N) Alt+Break 
Vv 分 析 (A) Ctrl+F5 
路 ”显示 估计 的 执行 计划 (P) CultL 
司 “IntelliSense 已 启用 (I) Curl+Q, Ctrl 


”包括 实际 的 执行 计划 (U) Ctrl+M 
了” 包括 实时 查询 统计 信息 
网 ” 包 丘 客 户 苇 统计 信息 (D Shift+Alt+S 
重 置 客户 铀 统计 信息 (E) 
马 SQLCMD 机 区 (M) 
将 结果 保存 到 (R) » 
外 查询 选项 


17-16 “查询 ”菜单 


(1) 连接 : 包括 4 个 子 菜单 ,主要 功能 如 下 。 

。 连接 : 打开 “连接 到 服务 器 ”对 话 框 ,与 服务 器 建立 连接 。 

。 断 开 连 接 : 断 开 当前 查询 编辑 器 与 服务 器 之 间 的 连接 。 

。 断 开 所 有 查询 : 断 开 当前 查询 编辑 器 中 的 所 有 查询 。 

。 更 改 连 接 : 打开 “连接 到 服务 器 ”对 话 框 ,与 其 他 服务 器 建立 连接 。 

(2) 在 对 象 资源 管理 器 中 打开 服务 器 : 如 果 服 务 器 处 于 断 开 状态 , 则 打开 服务 器 连接 。 

(3) 指定 模板 参数 的 值 : 用 于 对 模板 代码 指定 参数 。 

(4) 执行 : 执行 所 选 的 代码 , 若 没 选择 任何 代码 , 则 执行 查询 编辑 器 中 的 全 部 代码 。 

(5) 分 析 : 检查 所 选 代码 的 语法 。 如 果 没 有 选择 任何 代码 , 则 检查 整个 查询 编辑 器 窗 
口 的 语法 。 

(6) 取消 执行 查询 : 向 服务 器 发 送 取消 请 求 。 有 些 查询 不 能 立即 取消 ,而 必须 等 待 适 
当 的 取消 条 件 。 如 果 进 行 取消 ,在 回 滚 事务 时 可 能 发 生 延 迟 。 

(7) 显示 估计 的 执行 计划 : 从 查询 处 理 器 中 请 求 查询 执行 计划 而 不 实际 执行 查询 ,并 


在 “执行 计划 ”窗口 中 显示 该 计划 。 此 计划 使 用 索引 统计 值 作为 查询 执行 的 各 个 部 分 预期 返 
回 的 行 数 估 计 值 。 如 果 返 回 的 行 数 与 估计 值 有 明显 差距 ,并 且 查 询 处 理 器 更 改 了 执行 计划 
以 提高 效率 , 则 使 用 的 实际 查询 计划 会 与 估计 的 执行 计划 不 同 。 

(8) IntelliSense 已 启用 : IntelliSense 是 一 种 Microsoft 技术 ,这 种 技术 通过 光标 悬 停 
在 函数 上 时 显示 类 定义 和 注释 , 从 而 可 以 分 析 源 代码 。 在 IDE 中 输入 函数 名 时 ， 
IntelliSense 还 可 以 完成 这 些 名 称 。IntelliSense 会 在 用 户 编 辑 时 自动 插入 代码 ,包括 结束 标 
记 、 右 大 括号 以 及 值 两 边 的 引号 。 

(9) 在 SQL Server Profiler 中 跟踪 查询 : 启动 SQL Server Profiler 文件 跟踪 。 

(10) 在 数据 库 引 擎 优化 顾问 中 分 析 查 询 : 打开 数据 库 引 擎 优化 顾问 ,并 将 所 选 的 语法 
作为 工作 负荷 进行 分 析 。 

(11) 在 编辑 器 中 设计 查询 : 启动 查询 设计 器 工具 ,提示 指定 当前 查询 的 表 。 

(12) 包括 实际 的 执行 计划 : 执行 查询 ,返回 查询 结果 ,并 且 在 “执行 计划 ”窗口 中 以 图 
形 查 询 计 划 形 式 返 回 用 于 该 查询 的 执行 计划 。 

(13) 包括 实时 查询 统计 信息 : 执行 查询 ,返回 查询 结果 ,并 且 在 “客户 端 统计 信息 ” 窗 
口中 返回 统计 信息 。 

(14) 包括 客户 端 统计 信息 : 提供 一 个 “客户 端 统计 信息 ”窗口 ,其 中 包含 有 关 查 询 、 网 
络 数据 包 以 及 查询 占用 时 间 的 统计 信息 。 

(15) 重 置 客户 端 统计 信息 : 重新 提供 客户 端 统计 信息 。 

(16) SQLCMD 模式 : 使 用 SQLCMD 执行 所 选 的 请 法。 

(17) 将 结果 保存 到 : 按照 指定 方式 保存 查询 结果 。 通 常 有 如 下 三 种 形式 : 

@ 以 文本 格式 显示 结果 : 在 “结果 ”窗口 中 以 文本 格式 返回 查询 结果 。 

@ 以 网 格 显示 结果 : 在 “结果 "窗口 中 以 一 个 或 多 个 网 格 的 形式 返回 查询 结果 。 

@ 将 结果 保存 到 文件 : 在 执行 查询 时 ,“ 保 存 结 果 ” 对 话 框 将 会 打开 。 输 入 “文件 名 ”， 
再 单 击 “ 保 存 ” 按 钮 ,将 查询 结果 保存 为 带 有 . rpt 扩展 名 的 “报表 文件 ”。 对 于 高 级 选项 , 先 
单 击 “ 保 存 ” 按 钮 上 的 向 下 箭头 , 青 单 击 “ 编 码 保 存 ” 按 钮 。 

(18) 查询 选项 ; 打开 “查询 选项 ”对 话 框 ,如 图 17-17 所 示 ,配置 查询 执行 和 查询 结果 的 
默认 选项 。 


En > 
[5 于 | 人 上 外 之 机 ER 大生 娄 。 
|- 训 各 srmcom(o):p 固 
El rg 指定 从 SELECT 语 名 返回 9 text 和 ntext 数据 8 最 大 大 小 。 
| 3 SET TEKTSIZE(T): 2147453647 ” 几 | 字 节 
“克服 务 器 执行 时 值 为 0 表示 无 限期 竺 竺 (天 把 时 )。 
执行 SaHd 值 (): 严 图 外 
指定 可 用 于 分 也 批 籽 晶 99 字 或 字 行 
批 好 理 分 阴 符 @@): [50 
ES 
[|| WD | 


图 17-17 “查询 选项 ”对 话 框 
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8.“ 项 目 " 菜 单 

打开 “解决 方案 资源 管理 器 "时, SQL Server Management 
Studio 环境 中 的 菜单 栏 中 就 会 出 现 “ 项 目 ” 菜 单 ,如 图 17-18 所 示 。 
各 下 拉 菜 单 的 功能 主要 是 管理 项 目 文件 等 。 

在 SQL Server Management Studio 中 ,一 个 项 目 中 的 所 有 文 
件 都 必须 位 于 同一 个 物理 目录 下 ,该 目录 称 为 “项 目 目录 ”。“ 解 ”图 17-18 “项 目 " 菜 音 
决 方案 资源 管理 器 ”的 项 目 中 出 现 的 每 个 项 都 对 应 于 项 目 目录 中 
的 一 个 物理 文件 。 

SQL Server Management Studio 提供 了 大 量 用 于 创建 项 的 预定 义 模板 ,可 以 使 用 其 中 
一 个 模板 来 创建 开发 项 目 时 可 能 会 用 到 的 项 。 


17.2.2 自 定义 羔 单 栏 


SQL Server Management Studio 环境 提供 了 默认 的 菜单 栏 , 在 实际 工作 中 ,用 户 还 可 以 
对 菜单 栏 进行 修改 。 

自 定义 菜单 栏 就 是 对 现 有 的 菜单 栏 进行 修改 ,具体 步骤 如 下 : 

(1) 在 SQL Server Management Studio 中 选择 “工具 ”一 “ 自 定义 ”命令 ,在 弹出 的 “ 自 定 
义 ” 对 话 框 中 选择 “命令 ”选项 卡 ,如 图 17-19 所 示 。 此 对 话 框 允许 添加 和 移 除 菜单 上 的 命 
令 , 以 及 更 改 用 于 菜单 命令 的 图 像 。 各 项 内 容 的 含义 如 下 : 


自 定义 TX 
IRES)| 人 sto) | 
选择 要 重新 排列 的 萤 单 或 工具 巷 ; 
加 菜单 (8) | 某 单 栏 “ 
O 〇 工具 栏 0: SQL Server Analysis Services 久生 器 
〇 上 下 文 萤 单 00。 篇 名 中 上 下 文 茶 单 
控件 (C): 
新 荣 单 li。 添加 命令 (A)- 
文件 » , 
编辑 » 
视图 WV) » MI(D) 
查询 (Q) » 
L$(U) 
项 目 @®) » 下 移 (N) 
生成 (B) » NM 
调 工 (D) » 
XMLOO 全 部 重 雪 (R) 
表 &i 器 U 
数据 库 关系 图 (M) 
查询 设计 器 (R) > 
键 各 (0-… 关闭 


17-19 “ 自 定义 一 菜单 ”对 话 框 


菜单 栏 : 指定 在 "菜单 栏 ?列表 框 中 显示 的 基于 菜单 标题 ,而 标题 是 环境 当前 支持 
的 工具 和 设计 器 所 提供 的 。 该 标题 列表 是 动态 的 ,因此 类 别 和 菜单 标题 的 顺序 会 
更 改 , 具 体 取决 于 工具 和 设计 器 以 及 对 它们 所 做 的 任何 自 定义 。 所 以 来 自 不 同 设 
计 器 的 两 个 菜单 可 能 具有 同一 名 称 , 这 样 ,同一 标题 可 以 出 现 两 次 但 提供 不 同 的 
命令 集 。 
控件 : 根据 所 选择 的 菜单 类 别 显 示 命令 和 命令 图 像 。 
修改 所 选 内 容 : 显示 可 用 于 自 定 义工 具 栏 按钮 的 命令 列表 。 例 如 ,可 以 更 改 图 像 或 
快捷 键 , 以 及 指定 是 否 显示 命令 的 文本 而 非 图 像 。 
全 部 重 置 : 显示 ”全 部 重 置 ?对 话 框 , 它 允 许 用 户 重 命名 、 重 新 排列 `. 添 加 和 移 除 菜单 
和 工具 栏 上 的 命令 ,以 及 更 改 按钮 和 命令 图 像 。 

。 键 盘 : 显示 “选项 ”对 话 框 中 的 “键盘 ”页 ,以 便 指 定 命令 的 快捷 组 合 键 。 

(2) 选择 “菜单 栏 " 单 选 按 钮 ,可 以 在 右边 的 下 拉 列 表 框 中 选择 指定 的 菜单 项 ,如 “文件 ” 
菜单 ,如 图 17-20 所 示 。 


命 S(O) | 
寺 汉 要 于 新 排列 的 蓉 单 或 工具 巷 ; 
回 某 单 (B: | 文件 
© IAEM: SQL Server Analysis Services 编辑 器 
〇 上 下 文 党 单 0 护 术 溉 上 下 文 荣 单 
控件 (QO 


对 ConnectObjectExplorer 
对 断 开 连 接 


图 17-20 “菜单 栏 ?对 话 框 


(3) 利用 控件 自 定义 菜单 项 。 具体 用 法 如 下 : 

。 添加 命令 : 显示 “添加 命令 ”对 话 框 ,从 其 他 菜单 或 工具 栏 中 选择 命令 以 添加 到 正在 
编辑 的 菜单 或 工具 栏 中 。 

。 删 除 : 从 菜单 栏 中 移 除 命令 列表 中 选 定 的 命令 。 

。， 上 移 : 在 菜单 栏 上 将 选 定 的 命令 向 上 移动 一 个 位 置 。 第 

下 移 : 在 菜单 栏 上 将 选 定 的 命令 向 下 移动 一 个 位 置 。 17 

”。 修改 所 选 内 容 : 显示 其 他 自 定义 菜单 和 工具 栏 的 方法 的 列表 ,包括 重 置 (撤销 只 对 | 章 
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选 定 命令 所 做 的 更 改 )、 删 除 ( 移 除 选 定 命令 )、 名 称 (显示 命令 名 称 并 允许 编辑 名 称 
和 快捷 键 ) ,复制 按钮 图 像 ( 复 制 选 定 命令 的 按钮 图 像 )、 默 认 样式 ( 仅 显 示 工 具 栏 命 
令 的 按钮 图 像 或 仅 显 示 菜 单 的 按钮 图 像 和 命令 名 称 ) 等 。 

。 全 部 重 置 : 撤销 对 选 定 工具 栏 或 菜单 所 做 的 所 有 更 改 。 

(4) 修改 完毕 关闭 对 话 框 ,菜单 中 会 保存 修改 结果 。 


17.3 SQL Server 2016 工具 栏 的 使 用 


SQL Server 2016 提供 了 丰富 的 菜单 栏 和 工具 栏 ,一 般 来 说 ,工具 栏 就 是 常用 菜单 栏 或 
命令 的 图 形 化 ,可 以 更 加 方便 地 帮助 用 户 进行 操作 。 


17.3.1 常用 工具 栏 的 显示 


在 SQL Server Management Studio 中 一 般 显 示 标 准 工具 栏 , 其 他 的 工具 栏 可 以 选择 显 


示 或 隐藏 。 具 体操 作 如 下 : 
(1) 在 SQL Server Management Studio 中 选择 “工具 ”一 “ 自 定义 ”命令 ,弹出 “ 自 定义 ” 


对 话 框 ,选择 “工具 栏 ” 选 项 卡 ,如 图 17-21 所 示 。 


自 定 义 
工 REG) | 命 人 (0) | 
IRE(A): 


键盘 (Q- | | 关闭 


图 17-21 “工具 栏 ?选项 卡 
(2) 在 “工具 栏 ” 列 表 框 中 选中 某 个 复 选 框 , 则 相应 的 工具 栏 就 会 显示 到 SQL Server 
2016 窗 体 中 。 


17.3.2 创建 新 的 工具 栏 


SQL Server 2016 中 创建 新 的 工具 栏 实际 上 就 是 将 现 有 的 命令 项 或 工具 栏 项 添加 组 合 
成 新 的 用 户 工 具 栏 的 过 程 。 下 面 以 创建 名 为 “常用 工具 ”的 工具 栏 为 例 介绍 创建 用 于 SQL 
Server 2016 中 的 新 工具 栏 的 步骤 。 

(1) 在 SQL Server Management Studio 界面 中 选择 “工具 ”>“ 自 定义 ”命令 ,打开 “ 自 
定义 ”对 话 框 ,在 “命令 ”选项 卡 中 选择 “工具 栏 " 单 选 按 钮 ,如 图 17-22 所 示 。 其 中 的 控件 
含义 和 修改 菜单 项 的 功能 相近 ,只 是 “工具 栏 ? 下 拉 列 表 框 表示 可 以 选择 需要 修改 的 工 
具 栏 。 


自 定义 证 
工 上 ES 命 S(O) 
选择 要 重新 排列 的 荣 单 或 工具 栓 ; 
O 〇 荣 单 栏 (B)。。 | 某 单 栏 
加 工具 栏 ): | SQL 篇 名 器 ~ 
〇 上 下 文 荣 单 00: | 编 名 趾 上 下 文 荣 单 
控件 (O) 
于 连接 可 添加 命令 (A)-… 
对。 更改 连 接 (H).… 中 二 
| 
I 
和 上 敬 (U) 
? 执行 0 四 
bp RD) FE(N) 
加 。 取消 执行 查询 (N) PS 
v HA) 
器 ”里 示 估计 的 执行 计划 (@) 攻 了 了 
屠 ，“ 坦 询 选 项 - 
加 Intellisense 已 启用 QD 


17-22 “ 自 定义 一 工具 栏 ? 对 话 框 


(2) 单 击 “ 新 建 " 按 钮 ,在 * 新 建 工具 栏 "对 话 框 中 
输入 要 创建 的 工具 栏 名 字 “ 常 用 工具 ”, 如 图 17-23 所 
示 , 单 击 “ 确 定 ” 按 钮 ,新 工具 栏 建成 。 

(3) 为 新 建 工 具 栏 添加 命令 。 选 择 * 命 令 " 选 项 
卡 , 选 中 “工具 栏 " 单 选 按 钮 ,在 后 面 的 下 拉 列 表 框 中 
选择 自 定义 的 “常用 工具 ”工具 栏 ,如 图 17-24 所 示 。 图 17-23 “新 建 工 具 栏 ”对话 框 

(4) 单 击 “ 添 加 命令 ”按钮 ,在 “添加 命令 "对话 框 
中 依次 选择 需要 的 命令 (或 命令 按钮 ) .然后 单 击 “ 确 定 ” 按 钮 .如 图 17-25 所 示 。 

(5) 重复 此 过 程 , 则 “ 自 定义 ”对 话 框 中 就 会 显示 新 建 工 具 栏 中 要 添加 的 命令 (或 命令 按 | 第 
钮 ) ,如 图 17-26 所 示 。 单 击 “关闭 ”按钮 ,返回 “ 自 定义 ”对 话 框 。 1 
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* | 上 下 文采 单项 目 和 解决 方案 上 下 文 芝 单 | 解决 方案 | 未 加 
上 下 文 菜单 | 项 目 和 解决 方案 上 下 文 荣 单 | 跨 项 目的 多 项 
上 下 文采 单 | 项 目 和 解决 方 实 上 下 文 萤 单 | 器 项 目的 多 项 目 
上 下 文 菜单 | 项 目 和 解决 方案 上 下 文 茶 单 | 跨 项 目的 项 目 项 
上 下 文 菜单 | 项 目 和 解决 方 衬 上 下 文 茶 单 | 项 

上 下 文 菜单 | 项 目 和 解决 方案 上 下 文章 单 | 项 目 

上 下 文 菜单 | 项 目 和 解决 方案 上下文 萤 单 | 项 目 | 添加 

上 下 文 菜单 | 项 目 和 解决 方案 上 下 文 荣 单 | 项 目 | 调试 


图 17-25 添加 工具 栏 按钮 


定义 ? x 
IRES) $$(0) 
选择 要 重新 排列 的 菜单 或 工具 栏 : 
菜单 栏 (8): 可 单 栏 
® IAEM: 军用 工具 
〇 上 下 文 菜单 MI 往生 号 上 下 文 蔷 单 
控件 (Ch 
灿 更 切 0 添加 命令 (A)-- 
X wo) 
添加 新 葬 单 (E) 
区 DD 
a BD) 
RS [| 
FEN) 
修改 所 选 内 容 (M) ” 
全 部 要 于 (RR) 
键盘 (WO 关闭 


图 17-26 创建 “新 建 工具 栏 "命令 


(6) 在 “ 自 定义 ”对 话 框 中 单 击 “ 关 闭 ” 按 钮 ,新 工具 栏 2 全 -| 
“常用 工具 ”创建 成 功 ,如 图 17-27 所 示 。 


17.3.3 修改 工具 栏 图 17-27 ” 自 定义 工具 栏 


1. 重 排 工 具 栏 

重 排 工具 栏 和 重 排 菜单 栏 的 步 又 基本 相同 。 

(1) 在 SQL Server Management Studio 中 选择 “工具 ”一 “ 自 定义 ”命令 ,弹出 “ 自 定义 ” 
对 话 框 ,选择 “命令 ”选项 卡 。 

(2) 单 击 “ 重 排 命令 ”按钮 ,打开 “ 自 定义 ”对 话 框 。 选 择 “ 工 具 栏 ” 单 选 按钮 ,可 以 在 右边 
的 下 拉 列 表 框 中 选择 要 重 排 的 工具 栏 ,如 “标准 ”工具 栏 ,如 图 17-28 所 示 。 


图 17-28 自 定义 工具 栏 


(3) 利用 控件 重 排 菜 单项 。 具 体操 作 有 添加 、 删 除 、 上 移 、 下 移 、 修 改 所 选 内 容 和 重 
置 等 。 

(4) 重 排 完毕 关闭 对 话 框 必 标准 ?工具 栏 中 会 保存 修改 结果 。 

2. 添加 或 移 除 工具 栏 图 标 

同样 地 ,也 可 以 利用 “ 自 定义 ”对 话 框 将 图 标 添 加 或 移出 指定 工具 栏 。 如 在 “标准 ”工具 
栏 中 添加 部 分 常用 的 文字 编辑 功能 的 图 标 ,步骤 如 下 : 

(1) 在 SQL Server Management Studio 中 选择 “工具 ”一 “ 自 定义 ”命令 ,弹出 “ 自 定义 ” 
对 话 框 ,选择 “命令 ”选项 卡 。 

(2) 单 击 “ 重 排 命 令 ” 按 钮 ,弹出 “ 重 排 命令 ”对 话 框 。 选 择 “ 工 具 栏 ” 单 选 按 钮 ,可 以 在 右 和 
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边 的 下 拉 列 表 框 中 选择 要 添加 或 移 除 图 标的 工具 栏 , 如 “标准 ”工具 栏 。 章 
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(3) 单 击 “添加 ”按钮 ,弹出 “添加 命令 ”对 话 框 ,从 “类 别 " 列 表 框 中 选择 类 别名 称 如 “ 编 
辑 ”, 然 后 分 别 从 “命令 ”列表 框 中 选择 相应 的 “查找 “ 剪 切 “ 复 制 “ 粘 贴 ”等 命令 ,如 图 17-29 
所 示 。 


添加 命令 让 ， 关 

远 择 要 添加 的 命令 ， 然 后 单 二 "确定 "。 

类 到 (G): 命令 (D}: 

SSIS 加 所 对 入 代 和 ~ 

XML 困 插入 楼 式 切换 

帮助 | 插入 文件 

集训 | | “插入 制 志 符 一 

表 设 计 器 加 | 忆 卉 

查询 坦 找 上 一 个 

埋 记 设计 器 查找 上 一 个 (在 选 定 内 容 中 

窗口 喜 拭 所 有 引用 

多 维 数 据 焦 查找 下 一 个 

格式 查找 下 一 个 (在 选 定 内 容 中 ) 

I "| [os ES 
Cwe ]L | 


17-29 “添加 命令 ”对 话 框 


(4) 单 击 “ 确 定 ” 按 钮 ,返回 如 图 17-30 所 示 的 “ 自 定义 ”对 话 框 。 可 以 利用 添加 、 删 除 、 
上 移 、 下 移 修改 所 选 内 容 和 重 置 等 控件 进一步 调整 工具 栏 的 图 标 位 置 。 如 果 要 移出 图 标 ， 
可 以 通过 “删除 ”按钮 实现 。 


[5 


Analysis Services XMLA 查询 


图 17-30 在 “ 重 排 命令 ”对 话 框 中 修改 工具 栏 


(5) 调整 完毕 ,在 “ 自 定义 ”对 话 框 中 ,“ 标 准 ” 工 具 栏 如 图 17-31 所 示 。 利 用 “ 自 定义 ”对 
话 框 调整 出 适合 的 工具 栏 可 以 给 每 一 个 用 户 带 来 操作 上 的 方便 。 


工具 栏 (S$) | 命令 (0) 


园 择 要 本 新 排列 的 荣 音 或 工具 栏 : 
口 荣 音 栏 (B):。。 | 条 单 棕 
加 IREM: 。 | 标 入 ~ 
〇 上 下文 芝 单 0， 篇 名 要 上 下 文 浴 单 
控件 (C): 

EE | 
加 “打开 文件 O)- 
回 “保存 过 定 项 | 
AR | 


[sano- | 
图 17-31 修改 的 “标准 ”工具 栏 
(6) 如 果 想 恢复 系统 原先 的 “标准 ?工具 栏 ,如 图 17-30 所 示 , 单 击 “ 全 部 重 置 "按钮 即 可 
实现 操作 。 


17.4 在 查询 设计 器 中 调试 程序 的 基本 操作 


17.4.1 查询 设计 器 窗口 的 使 用 


SQL Server 2016 中 的 查询 设计 器 是 编辑 .调试 和 运行 SQL 脚本 的 界面 ,含有 编辑 、 消 
息 、 结 果 、 执 行 计划 、 客 户 端 统计 信息 等 多 个 窗口 。 应 用 查询 设计 器 的 工具 栏 和 使 用 菜单 功 
能 是 一 样 的 ,但 操作 比较 快捷 。 

使 用 查询 设计 器 可 以 编辑 现 有 的 存储 过 程 、 函 数 、 触 发 器 和 SQL 脚本 。 若 要 创建 对 数 
据 源 运行 的 新 的 SQL 语句 ,请 使 用 查询 设计 器 的 SQL 编辑 器 窗口 ,该 窗口 以 选项 卡 的 形式 
存在 ,可 以 通过 鼠标 单 击 来 选择 当前 选项 卡 。 在 SQL 编辑 器 窗口 中 可 以 通过 单 击 “ 执 行 ” 按 
钮 运行 当前 窗口 中 的 所 有 代码 ,也 可 以 通过 选择 实现 对 部 分 代码 的 运行 。 

SQL 编辑 器 提供 的 SQL 脚本 编辑 功能 主要 包括 : 

(1) 对 SQL 关键 字 进 行 颜色 编码 ,最 大 限度 地 减少 语法 和 拼写 错误 。 

(2) 生成 主干 存储 过 程 和 触发 器 。 

(3) 提供 有 用 的 编辑 功能 ,包括 剪 切 、 复 制 . 粘 贴 和 拖 动 操作 。 

(4) 通过 在 “工具 ”菜单 中 选择 “选项 ”对 话 框 更 改编 辑 器 的 行为 。 
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(5) 在 编辑 SQL 语句 时 , 某 些 Transact-SQL 语句 包含 在 由 细 线 环绕 的 框 中 。 这 有 助 
于 从 视觉 上 将 SQL 代码 分 为 不 同 的 命令 部 分 ,并 标识 出 可 以 使 用 查询 设计 器 以 图 形 方式 设 
计 的 SQL 语句 块 。 

查询 设计 器 的 常用 窗口 及 其 功能 如 下 : 

(1) 编辑 窗口 。 用 于 编辑 现 有 的 SQL 脚本 。 运 行 脚本 前 ,要 首 
先 明确 当 前 工作 数据 库 。 如 果 当 前 脚本 和 当前 工作 数据 库 不 匹配 ， 
可 以 通过 工具 栏 中 的 数据 库 下 拉 列 表 框 进行 选择 ,如 图 17-32 
所 示 。 

(2) 消息 窗口 。 用 于 对 最 近 进行 操作 的 成 功 与 错误 进行 提示 。 

(3) 结果 窗口 。 用 于 显示 最 近 进 行 操作 的 结果 。SQL Server 
2016 提供 三 种 查询 结果 的 显示 方式 ,更 改 查 询 方 法 可 以 通过 “查询 ” 
菜单 .快捷 菜单 或 工具 栏 实现 。 这 三 种 查询 结果 的 显示 方式 如 下 : 

@ 文 本 格式 显示 ,如 教材 例题 中 的 显示 结果 。 

@ 表格 显示 ,默认 方式 。 

@ 将 结果 保存 到 rpt 报表 文件 ,该 文件 可 以 由 Visual Studio 等 
开发 工具 调用 ,也 可 以 通过 打印 机 等 按照 表格 形式 打印 。 例 如 ,在 文本 中 打开 一 个 文件 
aaa. rpt, 如 图 17-33 所 示 。 


17-32 ”选择 当前 工作 
数据 库 


加 aa.rpt - 记事 本 —- OO x 
文件 (有 ” 妨 名 (E) 格式 (0) 查看 (V) 帮助 (H) 

courseno tname major teacherno A 
c05109 好 和 和 工程 t05001 


c05127 ” 张 t05002 
<c05127 E t05003 
c05138 。” 海 去 t 设 i t05011 
c05127 明 欣 

NULL 

c06127 

<c06172 思 : 
c08123 a 
c08106 


< > 


t08017 


17-33 ”显示 查询 结果 的 报表 方式 


(4) 执行 计划 窗口 。 执 行 计划 是 以 图 形 方 式 显示 SQL Server 查询 优化 器 所 选择 的 数 
据 检索 方法 。 图 形 执行 计划 使 用 图 标 来 表示 SQL Server 中 特定 语句 和 查询 的 执行 。SQL 
Server Management Studio 显示 丢失 了 哪些 统计 信息 ,从 而 强制 查询 优化 器 估计 谓词 选择 
性 ,然后 可 以 很 容易 地 创建 那些 丢失 的 统计 信息 。 

可 以 通过 “查询 ”菜单 或 单 击 工 具 栏 中 的 “包含 实际 的 执行 计划 ”, 然 后 运行 SQL 脚本 ， 
就 会 显示 该 查询 的 “执行 计划 ”, 如 图 17-34 所 示 。 

(5) 客户 端 统 计 信息 。 可 以 通过 “查询 ”菜单 或 单 击 工具 栏 中 的 “包含 客户 端 统 计 信 
息 ”, 然 后 运行 SQL 脚本 ,就 会 显示 客户 端 统计 信息 :如 图 17-35 所 示 , 包 括 三 方面 的 内 容 。 

中 查询 配置 文件 统计 信息 可 以 判断 该 SQL 语句 消耗 的 服务 器 资源 情况 。 

@ 网 络 统计 信息 可 以 判断 该 SQL 语句 消耗 的 网 络 资源 情况 。 

@ 时 间 统 计 信 息 可 以 判断 服务 器 与 客户 端 之 间 的 通信 情况 。 


国 结果 因 消息 ”执行 计划 
重 词 1: (与 访 批 有 天 的 ) 生词 逢 销 : 100% 


SELECT student.studentno, sname,daily, final FROM student join score ON student.— 


17-34 ”执行 计划 


国 结果 的 消息 ”执行 计划 | 唤 究 户 并 统计 信息 = 
查询 i 六 1 平均 
网 络 统计 信息 
服务 器 往返 的 次 堵 3 3 3.0000 
从 客户 庙 发 送 的 TDS 数据 包 3 3 3.0000 
从 服务 器 接收 的 TDS 数据 包 7 坟 7.0000 
从 客户 庙 发 送 的 字 节 数 728 3 728. 0000 
从 服务 器 接收 的 字 节 数 18995 十 18995.0000 
时 间 统计 信息 
客户 满 处 理 时 间 21 3 21.0000 
总 执行 时 间 分 3 21.0000 
服务 器 应 答 等 待 时 间 0 3 0.0000 


17-35 ”客户 端 统计 信息 


17.4.2 在 编辑 器 中 设置 查询 

在 查询 设计 器 中 ,还 可 以 通过 图 形 化 的 编辑 器 来 设置 查询 语句 ,通过 查询 内 容 、 查 询 结 
果 和 查询 语句 对 应 的 方法 可 以 更 快 地 掌握 Transact-SQL 查询 语句 的 用 法 。 

(1) 通过 “查询 ”菜单 或 单 击 工具 栏 中 的 “在 编辑 器 中 设计 查询 ”, 则 会 弹出 空白 的 “查询 
设计 器 ”对 话 框 ,以 及 如 图 17-36 所 示 的 “添加 表 ” 对 话 框 。 


dass 
count1 
course 
expic 
sc17 
score 
st.score 
stu_course 
FRR 
teach class 
teacher 
Wm | mm | | 6 
第 
图 17-36 “添加 表 ” 对 话 框 ” 
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(2) 分 别 选择 student 表 和 score 表 , 单 击 * 添 加 ”按钮 , 则 选择 的 两 个 表 就 会 添加 到 查 
询 设 计 中 ,然后 选择 要 输出 的 列 , 如 图 17-37 所 示 。 


sname student 


< 


SELECT student.studentno, score.daily, score.final, studentsname 
FROM student INNER JOIN 
score ON student.studentno = score.studentno AND student.studentno = score.studentno 


17-37 ”在 “查询 设计 器 ”中 设计 查询 


(3) 单 击 “ 确 定 ” 按 钮 ,生成 的 查询 会 出 现在 编辑 窗口 中 , 单 击 “ 执 行 ”按钮 ,查询 结果 如 
图 17-38 所 示 。 


SQLAQuery6.sql - L..dministrator (58)* x 
HSELECT student. studentno, score. daily, final, sname 
FROM student INNER JOIN score 
ON student. studentno = score. studentno 

100% -< 


助 结果 


studentno daily 


17111133071 82.00 
17111133071 77.00 
17112100072 87.00 
17112100072 97.00 
17112111208 85.00 
17112111208 69 nn 


图 17-38 ”执行 “设计 查询 语句 ”的 结果 


17.4.3 调试 SQL 程序 的 方法 


调试 程序 的 目的 就 是 通过 对 程序 进行 查 错 和 排 错 ,使 SQL 程序 的 运行 结果 能 够 符合 用 
户 的 要 求 。 调 试 SQL 程序 的 方法 主要 有 静态 检查 和 动态 调试 两 种 方式 。 

1. 人 工 检查 方式 

人 工 检查 就 是 面 对 静 态 的 查询 程序 代码 ,脑子 里 还 要 清楚 程序 执行 到 哪 一 个 语句 ,执行 
到 哪 一 步 程序 中 会 出 现 什么 结果 ,该 结果 是 否 符合 要 求 。 


人 工 检查 主要 从 以 下 几 个 方面 进行 : 

(1) 关键 字 是 否 正确 ? 通过 颜色 就 可 以 判断 。 

(2) 当前 数据 库 的 选择 是 否 合适 ? 当前 数据 库 的 选择 不 合适 ,有 时 容易 产生 误 操作 。 

(3) 单 引 号 是 否 是 英文 状态 ?如 果 不 是 , 则 引号 内 的 字符 串 将 不 显示 红色 。 

(4) 查询 输出 项 中 是 否 存在 数据 源 有 歧义 的 列 ? 如 果 存 在 ,应 指定 该 项 的 数据 源 。 

(5) 是 否 存 在 笛 卡 儿 积 查询 ? 如 何 处 理 ? 

(6) 是 否 采用 正确 的 缩 进 格式 输入 语句 ,利于 检查 程序 错误 ,可 读 性 强 。 

2. 动态 调试 SQL 程序 的 常用 方法 

(1) 输出 中 间 结 果 。 在 调试 较 复杂 的 查询 程序 时 ,可 以 先 选择 运行 子 查询 语句 ,输出 中 
间 结 果 ,然后 再 运行 整个 查询 。 

(2) 注释 语句 和 条 件 编译 。 将 部 分 可 能 出 现 问 题 的 语句 改 成 注释 方式 ,然后 调试 程序 ， 
若 能 够 得 到 正确 的 结果 , 则 要 排除 的 错误 可 能 就 在 改 成 注释 的 部 分 语句 中 。 

当然 ,对 简单 问题 的 调试 不 一 定 要 经 过 这 样 麻烦 的 步骤 ,用 其 他 方法 也 可 以 很 容易 
解决 。 


17.5 SQL Server 2016 的 常见 错误 与 处 理 


SQL Server 2016 提供 了 强大 的 错误 监视 和 处 理 机 制 。 主 要 表现 在 加 强 了 Transact- 
SQL 脚本 错误 处 理 功 能 和 提供 了 用 于 监视 SQL Server 2016 数据 库 服务 器 中 的 各 类 事件 
SQL Server 日 志 功 能 。 下 面 分 别 就 这 两 方面 进行 简要 的 介绍 。 


17.5.1 Transact-SQL 脚本 错误 处 理 功 能 


Transact-SQL 脚本 的 错误 处 理 主要 由 系统 函数 @@ERROR 和 Try…Catch 语句 的 差 

1. 系统 函数 @@ERROR 

在 SQL Server 2016 中 使 用 Transact-SQL 脚本 编程 时 ,可 以 在 脚本 中 使 用 系统 函数 四 
@ERROR 来 得 到 Transact-SQL 脚本 中 的 错误 号 。 即 如 果 前 一 个 Transact-SQL 语句 在 执 
行 时 没有 出 现 错误 ,该 函数 将 返回 0, 和 否则 返回 出 现 错误 的 类 型 号 。 若 是 系统 中 定义 的 错 
误 , 则 可 通过 系统 视图 sys. messages 来 查看 错误 号 所 代表 的 含义 。 

【 例 17.1】 利用 系统 函数 @@ERROR 处 理 Transact-SQL 脚本 错误 。 

程序 设计 过 程 和 代码 如 下 : 

(1) 在 “查询 编辑 器 ”窗口 中 输入 如 下 代码 : 

USE teaching 

DECLARE @a AS INT 

SET @a= 5/0 

PRINT N'Error = ' + CAST((@(@ERROR AS NVARCHAR(8)); 

(2) 单 击 “ 执 行 ” 按 钮 ,运行 上 述 Transact-SQL 脚本 ,其 结果 如 图 17-39 所 示 。 由 于 出 
现 了 严重 的 除数 零 错 误 , 所 以 “查询 编辑 器 ”自动 给 出 了 其 错误 的 相关 信息 (红色 ) ,而 代码 中 
的 @@ERROR 函数 也 向 用 户 返回 了 错误 的 代码 8134, 可 以 看 出 @@ERROR 函数 给 出 的 
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代码 与 系统 给 出 的 错误 代码 完全 相同 。 


国 洒 息 
消息 8134,， 级 别 16, 捧 态 1, 第 3 行 A 
遇 到 以 堆 作 除数 漠 旺 。 | 
Error = 8134 | 


100% -< | > 


图 17-39 运行 结果 
(3) 在 “查询 编辑 器 ”窗口 中 输入 下 面 的 代码 : 


SELECT * FROM SYS.MESSAGES 
WHERE message_id = '8134"' 


(4) 选中 上 述 两 行 代码 ,然后 单 击 “ 执 行 ”按钮 ,其 结果 如 图 17-40 所 示 。 


国 结果 四 消息 
message_ id lang.. severity is_event_.. text 
1033 16 0 Divide by zero error eneountered 
2 8134 1031 16 0 Fehler auferund einer Division durch ... 
3 8134 1036 16 0 Division par zéro. 
4 8134 1041 16 0 0 除 算 工 子 一 炉 强 生 L 去 L 大 。 
5 8134 1030 16 0 Der opstod en Division med nul-fejl, 
6 B134 3082 16 0 


Error de divisibn entre cero. 


17-40 查询 结果 


从 图 17-40 中 可 以 看 出 错误 号 为 8134 所 对 应 的 文本 信息 ,其 中 列 出 了 与 该 错误 信息 相 
关 的 9 种 语言 的 说 明文 本 。 

2. Try…Catch 语句 功能 

Try…Catch 语句 是 SQL Server 2016 提供 的 新 的 差错 捕捉 功能 。 该 功能 类 似 于 C# 和 
C++ 语言 中 异常 处 理 的 错误 处 理 。 在 编写 Transact-SQL 脚本 时 ,可 以 将 需要 监控 的 脚本 语 
句 体 包 含 在 TRY 块 中 。 如 果 TRY 块 内 部 发 生 错误 , 则 会 将 控制 传递 给 CATCH 块 中 包含 
的 差错 处 理 语句 。 

TRY…CATCH 构造 可 捕 提 所 有 严重 级 别 大 于 10 但 不 终止 数据 库 连 接 的 错误 。 

严重 级 别 从 0 一 10 的 错误 是 信息 性 消息 ,并 不 导致 执行 从 TRY…CATCH 构造 的 
CATCH 块 中 跳 转 。 

终止 数据 库 连 接 的 错误 (通常 严重 级 别 为 20 一 25) 不 由 CATCH 块 处 理 , 因 为 连接 终止 
后 执行 也 终止 了 。 

Try…Catch 的 使 用 语法 如 下 所 示 : 


BEGIN TRY 

{ sql_statement | statement block } 
END TRY 
BEGIN CATCH 

{ sql_statement | statement block } 
END CATCH 
[;] 


【 例 17.2】 使 用 Try…Catch 功能 处 理 TransactrSQL 脚本 错误 。 
具体 设计 过 程 如 下 。 
(1) 在 “查询 编辑 器 ”窗口 中 输入 如 下 代码 : 
USE teaching 
DECLARE @Result AS INT 
DECLARE @a RS INT 
SET @a=0 
BEGIN TRY 
SET @Result = 3/@a 
END TRY 
BEGIN CATCH 
PRINT N'Error = ' + CAST((@(@ERROR RS NVARCHAR(6)); 
END CATCH; 
(2) 单 击 “ 执 行 ” 按 钮 ,运行 上 述 Transact-SQL 诗 填 
脚本 ,其 结果 如 图 17-41 所 示 。 eo 村 
除了 上 面 介 绍 的 用 于 处 理 Transact-SQL 脚本 错 
误 的 基本 功能 之 外 ,SQL Server 2016 还 提供 了 与 之 10% -。 > 
相关 的 更 多 功能 ,例如 使 用 错误 函数 。TRY…CATCH 
使 用 错误 函数 来 捕获 错误 信息 。 
。 ERROR_NUMBER(): 返回 错误 号 。 
。 ERROR_MESSAGE(): 返回 错误 消息 的 完整 文本 。 此 文本 包括 为 任何 可 替换 参数 
(如 长 度 、 对 象 名 称 或 时 间 ) 提 供 的 值 。 
。ERROR_SEVERITY(): 返回 错误 严重 性 。 
。 ERROR_STATEQO: 返回 错误 状态 号 。 
。 ERROR_LINE(): 返回 导致 错误 的 例 程 中 的 行 号 。 
。 ERROR_PROCEDUREQO: 返回 出 现 错误 的 存储 过 程 或 触发 器 的 名 称 。 
可 以 使 用 这 些 函 数 从 TRY…CATCH 构造 的 CATCH 块 的 作用 域内 的 任何 位 置 检索 
错误 信息 。 如 果 在 CATCH 块 的 作用 域 之 外 调用 错误 函数 .错误 函数 将 返回 NULL。 
3. RAISERROR 语句 
RAISERROR 用 于 将 与 SQL Server 数据 库 引 擎 生成 的 系统 错误 或 警告 消息 使 用 相同 
格式 的 消息 返回 到 应 用 程序 中 。RAISERROR 的 功能 如 下 : 
(1) 通过 sp_addmessage 系统 存储 过 程 创建 用 户 定义 的 错误 消息 。 这 些 消息 的 消息 号 
大 于 50 000 ,可 在 sys. messages 目录 视图 中 查看 这 些 消息 。 
(2) 在 RAISERROR 语句 中 指定 消息 字符 串 ,检查 数据 值 ,返回 包含 变量 文本 的 消息 。 
替换 消息 正文 中 的 参数 值 。 
(3) 分 配 特定 的 错误 号 、 严 重度 和 状态 。 
(4) 请 求 将 错误 记录 到 数据 库 引 擎 错误 日 志和 Microsoft Windows 应 用 程序 日 志 中 。 
帮助 对 Transact-SQL 代码 进行 故障 排除 。 
(5) 导致 执行 从 TRY 块 跳 到 关联 的 CATCH 块 。 将 错误 信息 从 CATCH 块 返回 到 进 
行 调用 的 批 处 理 或 应 用 程序 。 章 


17-41 运行 结果 
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RAISERROR 语句 的 语法 格式 如 下 : 


RAISERROR ( { msg_id | msg_str | @local variable } 
{ ,severity ,state } 
[ ,argument [,...n]]) 


[ WITH option [ ,...n]] 
格式 中 各 参数 含义 如 下 : 


(1) msg_id: 使 用 sp_addmessage 存储 在 sys. messages 目录 视图 中 的 用 户 定义 错误 消 
息 号 。 用 户 定义 错误 消息 的 错误 号 应 当 大 于 50000。 如 果 未 指定 msg_id, 则 RAISERROR 
引发 一 个 错误 号 为 50000 的 错误 消息 。 

(2) msg_str: 用 户 定义 消息 ,该 错误 消息 最 长 可 以 有 2047 个 字符 。msg_str 是 一 个 字 
符 串 。 

(3) @1local_variable: 表示 包含 按照 msg_str 的 方式 格式 化 的 字符 串 的 任何 有 效 字符 
串 数据 类 型 的 变量 。 

(4) severity: 用 户 定义 的 与 该 消息 关联 的 严重 级 别 。 当 使 用 msg_id 引发 使 用 sp_ 
addmessage 创建 的 用 户 定义 消息 时 ,RAISERROR 上 指定 的 严重 性 将 覆盖 sp_addmessage 
中 指定 的 严重 性 。 

(5) state: 介 于 1 一 127 的 任意 整数 。 如 果 在 多 个 位 置 引 发 相同 的 用 户 定 义 错误 , 则 针 
对 每 个 位 置 使 用 唯一 的 状态 号 有 助 于 找到 引发 错误 的 代码 段 。 

(6) argument: 用 于 代替 msg_str 或 对 应 于 msg_id 消息 中 定义 的 变量 的 参数 。 

(7) option: 错误 的 自 定 义 选 项 ,可 以 是 LOG( 日 志 )、NOWAIT( 将 消息 立即 发 送 给 客 
户 端 ) 、SETERROR( 设 置 错误 级 别 ) 中 的 任 一 值 。 

当 RAISERROR 语句 在 sys. messages 中 用 于 用 户 定 义 消息 的 msg_id 时 ,msg_id 将 被 
作为 SQL Server 错误 号 或 本 机 错误 代码 返回 。 而 当 RAISERROR 用 于 msg_str 而 不 是 
msg_id 时 , 则 返回 的 SQL Server 错误 号 和 本 机 错误 号 为 50000。 

当 使 用 RAISERROR 返回 用 户 定义 的 错误 消息 时 ,请 在 每 个 引用 该 错误 的 
RAISERROR 中 使 用 不 同 的 状态 号 码 。 这 可 以 在 发 生 错 误 时 帮助 用 户 进行 错误 诊断 。 对 
于 没有 针对 此 错误 的 帮助 ,如 果 错 误 信息 中 的 文本 未 能 提供 足够 的 信息 解决 此 问题 ,可 考虑 
选用 以 下 方法 : 

(1) 验证 设置 是 否 正确 ,并 青 次 尝试 操作 。 

(2) 使 用 索引 搜索 与 该 错误 信息 相关 的 关键 字 。 

(3) 如 果 问 题 是 由 外 部 应 用 程序 或 软件 引起 的 , 则 参考 相关 部 分 的 文档 。 例 如 ,错误 可 
能 是 由 数据 库 软件 .服务器 设置 甚至 是 正在 使 用 的 网 络 引 起 的 。 

(4) 对 于 SQL 语句 错误 , 则 参考 数据 库 软件 ,以 确保 使 用 正确 的 数据 库 语 法 。 

(5) 查看 自述 文件 中 关于 该 错误 的 最 新 信息 。 

【 例 17.3】 在 sys. messages 目录 视图 中 设置 即时 消息 ,该 消息 通过 sp_addmessage 系 
统 存储 过 程 ,以 消息 号 50005 被 添加 到 sys. messages 目录 视图 中 。 

sp_addmessage @msgnum = 50005, 


@severity = 10, 
@msgtext = N'‘<<%10.6s>>'; 


GO 

select message_id from sys. messages 

go 

RAISERROR (50005, 10, 1， N' 自 定义 错误 号 '); 
GO 

sp_dropmessage @msgnum = 50005; 

GO 


17.5.2 查看 SQL Server 2016 数据 库 服务 器 中 的 错误 事件 


像 Windows 自 带 的 “事件 查看 器 "一样 ,SQL Server 2016 提供 了 用 于 记录 SQL Server 
数据 库 服务 器 中 事件 的 SQL Server 日 志 功 能 。 

通常 情况 下 ,SQL Server 2016 会 将 某 些 系统 事件 和 用 户 自 定义 事件 同时 记录 到 SQL 
Server 日 志和 Windows 应 用 程序 日 志 中 。 其 中 , Windows 自 带 的 “事件 查看 器 ”记录 的 内 
容 包含 Windows 操作 系统 事件 .SQL Server 事件 以 及 SQL Server 代理 事件 。 而 “SQL 
Server 日 志 ” 功 能 则 只 会 记录 出 现在 SQL Server 数据 库 系统 中 的 事件 。 

某 些 情况 下 ,从 SQL Server 日 志 中 可 能 只 能 获得 某 些 不 明 原 因 的 错误 消息 ,此 时 可 以 
将 其 与 Windows 日 志 中 的 事件 进行 对 比 ,并 从 中 查找 造成 错误 的 可 能 原因 。 此 外 ,使 用 
SQL Server Management Studio 的 日 志文 件 查看 器 还 可 以 将 SQL Server、SQL Server 代理 
和 Windows 日 志 集 成 到 一 个 列表 中 ,从 而 可 以 轻松 了 解 相关 的 服务 器 事件 和 SQL Server 
事件 。 

启用 SQL Server 日 志 功能 的 方法 如 下 。 

(1) 在 “资源 管理 器 ”下 展开 “管理 ”一 “SQL Server 日 志 ” 子 目录 。 可 以 在 此 节点 下 查 
看 SQL Server 日 志 记 录 。 通 常情 况 下 ,SQL Server 2016 会 自动 保留 6 个 日 志 的 备份 。 

(2) 如 果 需 要 SQL Server 2016 保存 更 多 的 备份 ,可 右 击 “SQL Server 日 志 ” 节 点 ,在 弹 
出 的 快捷 菜单 中 选择 “配置 "命令 ,打开 “配置 SQL Server 错误 日 志 ” 对 话 框 ,选中 “限制 错误 
日 志文 件 在 回收 之 前 的 数目 ” 复 选 框 ,然后 根据 需要 在 “最 大 错误 日 志文 件数 "文本 框 中 输入 
指定 的 数字 即 可 ,如 图 17-42 所 示 。 

(3) 如 果 想 要 查看 指定 的 日 志文 档 ,可 双击 该 日 志文 档 ,打开 “日 志文 件 查看 器 "对 话 
框 。 该 对 话 框 中 包含 了 SQL Server、SQL 代理 .Windows NT 以 及 “数据 库 邮 件 ” 选 项 中 出 
现 的 事件 ,如 图 17-43 所 示 。 

(4) 从 图 17-43 中 可 以 看 出 ,日 志文 件 中 的 日 志 记 录 非 常 多 ,此 时 也 可 以 根据 需要 设置 
相应 的 筛选 条 件 对 日 志 记录 进行 筛选 。 

(5) 单 击 “ 查 看 筛选 设置 "链接 ,打开 “筛选 设置 ”对话 框 ,用 户 可 以 根据 需要 设置 相应 的 
筛选 条 件 。 例 如 ,如 果 想 查看 所 有 与 teaching 数据 库 相 关 的 事件 记录 ,可 以 在 “消息 包含 文 
本 ”文本 框 中 输入 teaching, 然 后 选中 “应 用 筛选 器 ” 复 选 框 ,如 图 17-44 所 示 。 

(6) 单 击 “ 确 定 ” 按 钮 , 即 可 从 当前 的 日 志文 档 中 找到 所 有 与 teaching 相关 的 日 志 记录 。 
除 此 之 外 ,还 可 以 单 击 “ 日 志文 件 查看 器 ”窗口 中 的 “加 载 日 志 ” 按 钮 ,或 单 击 “ 导 出 ”按钮 将 当 
前 的 日 志 查询 结果 导出 。 


SQL Server 2016 环境 下 的 上 机 指 蛙 
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目 配置 SQL Server 错误 日 志 - 0 x 
EL. 
回 限制 糟 误 日 志文 件 在 回收 之 前 的 赦 目 (L) 
最 大 错误 日 志文 件数 00 - E S 


值 必须 介 于 5 到 99 之 则 。 


服务 器 
L637CEYPESYNCSG 


连 培 
LOG37CEYPE9YWCSG\Adninistrat 


于 查看 入 接 屋 性 


I 


17-42 “配置 SQL Server 错误 日 志 ” 对 话 框 


和 萝 昌 志 文件 查 看 器 - LG37CEYPE9YWCSG 一 口 里 
启 加 堪 昌 志 税 号 出 固 届 新 了 入 下 .4 搜索 园 停 止 四 二 
日 志文 件 摘要 (S): 未 应 用 任何 第 选 器 
| 存 1 1 一 2018/3/1 17-35:00 上 BB 期”  _ 源 消息 ~ 
存档 编号 2 - 2018/3/1 9:14:00 是 2018/3/2 13:51:08 | Backup BACEUP DATABASE successfully processed 370 pages i: 间 
bane 1 | 2018/3/2 13:51:08 Backup Database backed up. Database: test01，ereation dat 
存档 编号 5 一 2018/2/27 出 2018/3/2 13;51;01 Logon Login failed for user “WT SERYICE\SQLSERVERAGENT 
图 ey 目 2018/3/2 13:51:01 。 Legen 。 模 误 : 16456， 严 重 性 : 14， 状态 : 38。 
田口 趣 据 库 邮 件 日 2018/3/2 13:50:33 Logon Login fsiled for user “WT SERVICEVSQLSERYERAGENT 
BNinkee w 目 2018/3/2 13:50:33 。 Logon 。 模 误 :18456， 严 重 性 14， 状态 : 36。 
目 2018/3/2 13:50:29 Backup BACKUP DATABASE successfully processed 370 pages i 
量 2018/3/2 13:50:29 Backup Database backed up. Database; test01，ecreation dat 
目 2018/3/2 13;49:51 Logon Login failed for user “WT SERYICE\SQLSERVERAGENT 
目 2018/3/2 13:49:51 ”Logon 错误 : 18456， 严 重 性 : 14， 状态 : 39。 
日 2018/3/2 13:49:49 Backup BACEUP DATABASE successfully processed 370 pages i 
护 旧 2018/3/2 13:49:49 Backup Database backed up. Database; test01l, creation dat 
上 次 刷新 上 昌 2018/3/2 13:49:26 Logon Login failed for user “NT SERVICEVSQLSERVERAGENT 
由 2018/3/2 13:49:26 Logon ”错误 ;16456， 严 重 性 : 14， 状态: 36。 v 
2018/3/2 13:51:34 < Ess > 
[所 先行 详 钙 信息 可 )- 
第 造 器 : 无 其 汪 13:51:08 ~ 
了 了 可 下 扩 太 8 时 站 SQL Server (当前 - 2018/3/1 17:37:00) 
Backup 
六 和 
ACERP DATABASE zaceessfully processed 370 pages in 0 362 seconds (7.567 MB/sec). 
四 已 完成 (600 条 记录 )。 
关闭 (c) 


17-43 “日 志文 件 查看 器 ”窗口 


2018/3/1 
2018/3/3 


应 用 委 选 器 (F) 


17-44 “筛选 设置 ”对话 框 


17.5.3 常见 错误 和 错误 级 别 


SQL Server 2016 中 的 错误 一 般 分 为 用 户 定义 的 错误 和 系统 的 错误 两 类 。 

数据 库 引 擎 实例 中 所 有 系统 和 用 户 定义 的 错误 消息 都 包含 在 sys. messages 目录 视图 
中 ,而 RAISERROR 语句 可 用 于 将 用 户 定 义 的 错误 返回 到 应 用 程序 。 

所 有 数据 库 应 用 程序 编程 接口 (Application Program Interface,API) ,如 .NET Framework 
SQL-Client 命名 空间 以 及 ActiveX 数据 对 象 (ActiveX Data Objects,ADO) 等 都 会 报告 基本 
错误 属性 ,其 中 包括 错误 号 和 消息 字符 串 。 

当 错 误 是 由 SQL Server 2016 数据 库 引 擎 引起 时 ,此 错误 的 严重 性 可 说 明 SQL Server 
所 遇 到 问题 的 类 型 。 由 SQL Server 数据 库 引擎 引起 的 错误 属性 如 表 17-1 所 示 。 


表 17-1 SQL Server 数据 库 引 擎 引起 的 错误 属性 


属 性 说 明 
错误 号 每 个 错误 消息 具有 唯一 的 错误 号 
错误 消息 字符 串 错误 消息 包含 关于 错误 原因 的 诊断 信息 。 许 多 错误 消息 都 有 替换 变量 
严重 性 严重 性 指示 错误 的 严重 程度 。 严 重 性 较 低 的 错误 ,如 1 级 或 2 级 为 信息 性 消息 
或 低级 警告 。 严 重 性 较 高 的 错误 指示 需要 尽快 解决 的 问题 
某 些 错误 消息 可 能 在 数据 库 引 擎 代码 中 多 处 出 现 。 查 看 已 知 问题 的 数据 库 时 ， 
状态 可 以 使 用 状态 号 确定 所 记录 的 问题 是 否 与 曾 遇 到 的 错误 相同 。 例 如 ,如 果 一 篇 
知识 库 文章 讨论 状态 为 2 的 1105 错误 ,而 接收 到 的 1105 错误 消息 状态 为 3, 则 
错误 原因 可 能 不 同 于 文章 所 报告 的 原因 
如 果 错 误 出 现在 存储 过 程 或 触发 器 中 ,那么 这 就 是 发 生 错误 的 存储 过 程 或 触发 
过 程 名 称 器 名 称 
行 号 行 号 指示 在 批 处 理 , 存 储 过 程 , 触 发 器 或 函数 中 生成 错误 的 语句 1 
章 
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1. 错误 严重 性 级 别 
表 17-2 列 出 并 说 明 SQL Server 2016 数据 库 引 擎 所 引起 错误 的 严重 性 级 别 。 


表 17-2 数据库 引 擎 错误 的 严重 性 级 别 


级 别 说 明 

返回 不 太 严重 的 状态 信息 或 报表 错误 的 信息 性 消息 。 数 据 库 引 擎 不 会 引起 严重 级 别 为 
0 一 9 的 系统 错误 

10 返回 不 太 严重 的 状态 信息 或 报表 错误 的 信息 性 消息 

11~16 ”| 指示 可 由 用 户 纠正 的 错误 

强 指示 给 定 的 对 象 或 实体 不 存在 

特殊 严重 性 ,用 于 因 特 殊 查询 提示 而 不 使 用 锁定 的 查询 。 在 某 些 情况 下 ,因为 没有 用 锁 保 
证 一 致 性 ,由 这 些 语句 所 执行 的 读 取 操 作 会 产生 不 一 致 的 数据 

13 指示 事务 死 锁 错误 

14 指示 安全 性 相关 错误 ,如 权限 被 拒绝 

15 指示 Transact-SQL 命令 中 的 语法 错误 

16 指示 可 由 用 户 纠正 的 常规 错误 

17 一 19 “| 指示 无 法 由 用 户 纠 正 的 软件 错误 ,请 将 问题 通知 系统 管理 员 

指示 语句 导致 SQL Server 用 尽 资源 (如 数据 库 的 内 存 、 锁 或 磁盘 空间 ) 或 超出 了 系统 管理 
员 设 置 的 某 些 限制 

指示 数据 库 引擎 软件 有 问题 ,但 可 完成 执行 语句 ,并 且 可 维护 到 数据 库 引 擎 实例 的 连接 。 
每 当 出 现 严重 级 别 为 18 的 消息 时 均 应 通知 系统 管理 员 

指示 超出 了 不 可 配置 的 数据 库 引擎 限制 并 且 当 前 批 处 理 已 终止 。 严 重 级 别 为 19 或 更 高 
的 错误 消息 将 停止 执行 当前 的 批 处 理 。 严 重 级 别 为 19 的 错误 很 少 ,必须 由 系统 管理 员 或 
主要 支持 提供 商 更 正 。 当 引发 严重 级 别 为 19 的 消息 时 ,请 与 系统 管理 员 联 系 。 严 重 级 别 
为 19 一 25 的 错误 消息 均 写 人 错误 日 志 

指示 系统 问题 且 是 致命 错误 。 此 范围 内 的 错误 消息 可 以 影响 同一 数据 库 中 所 有 正在 访问 
数据 的 进程 ,并 可 能 指示 数据 库 或 对 象 已 损坏 

20 指示 语句 遇 到 了 问题 。 由 于 该 问题 只 影响 了 当前 任务 ,数据 库 本 身 未 必 已 经 损坏 

21 指示 遇 到 了 影响 当前 数据 库 中 所 有 任务 的 问题 ,但 数据 库 本 身 未 必 已 经 损坏 

22 指示 消息 中 所 指定 的 表 或 索引 因 软 件 或 硬件 问题 而 损坏 

23 指示 整个 数据 库 的 完整 性 因 硬 件 或 软件 问题 而 出 现 问题 

24 指示 介质 故障 。 系 统管 理 员 可 能 需要 还 原 数据 库 


19 


20 一 25 


2. 用 户 定义 的 错误 消息 严重 性 

SQL Server 2016 中 可 以 使 用 sp_addmessage 系统 存储 过 程 将 严重 级 别 为 1 一 25 的 用 
户 定义 错误 消息 添加 到 sys. messages 目录 视图 中 。 这 些 用 户 定 义 的 错误 消息 可 供 
RAISERROR 语句 使 用 。 

可 用 RAISERROR 生成 严重 性 级 别 为 1 一 25 的 用 户 定 义 错误 消息 。RAISERROR 可 
以 引用 sys. messages 目录 视图 中 存储 的 用 户 定义 错误 消息 或 者 动态 地 生成 消息 。 生 成 错 
误 时 如 果 使 用 sys. messages 中 的 用 户 定义 错误 消息 , 则 RAISERROR 指定 的 严重 级 别 将 

盖 sys. messages 中 指定 的 严重 级 别 。 

需要 注意 的 是 ,由 SQL Server 数据 库 引 擎 或 RAISERROR 语句 产生 的 错误 不 是 结果 

集 的 一 部 分 。 错 误 通 过 独立 于 结果 集 处 理 的 错误 处 理 机 制 返回 给 应 用 程序 。 


第 3 部 分 
SQL Server 2016 数 据 库 实 验 


学 习 导 读 : 

本 部 分 包括 本 课程 的 实验 指导 和 实验 内 容 两 方面 内 容 。 

实验 指导 部 分 包括 本 课程 实验 的 基本 规范 和 建议 。 

实验 内 容 部 分 共 包 括 16 个 实验 ,实验 的 运行 环境 是 SQL 
Server 2016 软件 。 实 验 1 一 实验 15 对 应 教材 的 相关 内 容 。 实 
验 16 是 综合 性 实验 ,通过 图 书 管理 数据 库 Library 的 数据 库 对 
象 的 创建 和 管理 将 SQL Server 2016 软件 的 基本 操作 进行 系 
统 的 演示 和 深化 。 

实验 过 程 中 ,建议 除了 利用 本 书 的 代码 外 ,还 可 以 不 断 修 改 
各 种 数据 和 参数 进行 实验 操作 。 在 实验 过 程 中 ,对 于 可 视 化 部 
分 的 操作 ,可 以 多 党 试 操作 一 下 教材 中 因 篇 幅 关 系 未 介绍 的 
操作 。 


第 18 章 实验 指导 与 实验 内 容 


学 习 SQL Server 2016 数据 库 需 要 在 掌握 部 分 理论 内 容 的 同时 进入 实验 环节 。 只 有 在 
熟悉 SQL Server 的 集成 运行 环境 的 基础 上 ,进行 数据 库 的 基本 操作 ,注重 学 生 应 用 创新 能 
力 的 培养 ,才能 全 面 提高 学 生 的 数据 库 设 计 和 管理 的 水 平 。 这 也 是 学 习 本 课程 的 主要 目的 。 

本 课程 实验 可 安排 32 学 时 左右 , 共 安 排 16 个 实验 。 教 师 可 根据 实际 需要 对 实验 内 容 
进行 摘 选 或 补充 。 讲 课 与 上 机 的 课时 比例 应 该 掌握 在 3 : 2 左右 。 


18. 1 SQL Server 2016 的 实验 指导 


1. 上 机 实 蛤 的 目的 和 要 求 

学 习 SQL Server 2016 数据 库 应 当 在 达到 能 够 独立 地 创建 和 组 织 数 据 库 、 独 立 上 机 调 
试 程序 和 分 析 结 果 的 目标 后 ,进一步 加 深 对 SQL Server 数据 库 的 有 关 理 论 的 理解 及 提高 编 
程 的 基本 技能 。 所 有 计算 机 类 课程 都 要 求实 践 性 经 验 ,没有 足够 的 上 机 实践 ,学 习 好 SQL 
Server 乃至 其 他 大 型 数据 库 是 不 可 能 的 。 

上 机 实验 的 目的 不 仅仅 是 为 了 验证 教材 和 讲课 的 内 容 或 者 验证 自己 所 编 的 程序 正确 与 
和 否 , 更 重要 的 是 通过 实际 题目 的 上 机 实验 ,可 以 提高 动手 能 力 、 提 高 分 析 问 题 和 解决 问题 的 
能 力 。 具 体 来 说 ,上 机 实验 的 目的 应 该 从 以 下 几 个 方面 进行 理解 。 

(1) 加 深 对 SQL Server 语言 基础 的 理解 。 对 于 初学 者 来 说 ,仅仅 通过 课堂 教学 很 难 将 
课程 要 求 的 内 容 记 住 并 理解 透彻 .尤其 是 比较 琐碎 的 数据 类 型 .多 种 多 样 的 函数 .灵活 多 变 
的 规则 等 。 只 有 通过 多 次 上 机 ,不断 地 思考 .归纳 和 总 结 才能 够 熟练 地 掌握 相关 内 容 。 通 过 
实验 可 以 快速 地 掌握 语法 规则 、 验 证 自己 的 能 力 、 加 深 自己 对 数据 库 理论 的 认识 。 

(2) 了 解 和 熟悉 SQL Server 语言 程序 开发 的 环境 。 一 个 程序 必须 在 一 定 的 硬件 和 软 
件 环境 下 才能 运行 。 使 用 者 应 该 了 解 ,为 了 运行 一 个 SQL Server 程序 需要 哪些 必要 的 外 部 
条 件 (例如 硬件 配置 .软件 配置 ) ,可 以 利用 哪些 系统 的 功能 来 帮助 自己 开发 数据 库 。 几 乎 所 
有 的 基本 操作 都 可 以 通过 SQL Server Management Studio 来 实现 。SQL Server 2016 用 户 
的 数据 库 文件 .SQL 语言 文件 的 存储 也 应 该 设置 固定 的 路 径 , 防 止 出 现 文件 存放 位 置 混乱 ， 
在 调试 程序 时 浪费 较 多 的 资源 。 

(3) 实验 模式 的 探讨 。 上 机 实验 是 SQL Server 2016 贯穿 整个 数据 库 操作 的 教学 过 程 。 
实验 不 再 是 单一 的 上 机 调试 程序 ,建议 根据 学 生 的 基础 和 课时 要 求 按 阶 段 分 成 两 种 模式 : 
上 机 验证 和 自由 上 机 。 

上 机 验证 是 指 学 生根 据 实验 指导 书 的 操作 步骤 进行 操作 ,并 认真 做 好 记录 。 这 种 方式 
一 定 让 学 生 先 做 好 实验 的 预习 ,教师 在 答疑 过 程 中 对 于 普遍 存在 的 问题 及 时 进行 总 结 。 
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自由 上 机 是 指 当 学 生 掌 握 了 调试 程序 的 基本 方法 后 ,可 以 采取 自由 上 机 的 方式 ,学生 之 
间 可 以 边 实 验 边 交流 ,从 而 进一步 提高 学 生 调 试 程序 的 能 力 ,增强 学 生 学 习 SQL Server 程 
序 语言 的 自信 心 。 还 可 以 充分 利用 网 络 , 把 各 种 网 络 教 学 资源 有 机 地 整合 到 实验 教学 中 来 。 
提供 合适 的 交流 平台 ,可 以 提高 学 生 学 习 的 积极 性 。 

2. 实验 内 容 的 设置 

针对 本 课程 实验 内 容 的 不 同 特点 ,可 以 将 实验 分 为 熟悉 环境 阶段 .基本 操作 阶段 和 技术 
提高 阶段 三 个 阶段 ,其 主要 内 容 和 基本 要 求 如 下 。 

(1) 熟悉 环境 阶段 。 前 期 准备 阶段 的 主要 任务 是 理解 数据 库 、 数 据 模型 和 数据 库 系统 
的 基本 概念 ; 根据 要 求 自 己 设计 出 一 个 结构 合理 的 数据 库 ,并 且 熟 悉 SQL Server 2016 集成 
环境 的 使 用 及 数据 库 和 表 的 建立 ,数据库 完整 性 设置 等 。 该 阶段 可 以 针对 教材 的 第 1 一 4 章 
内 容 进行 设置 。 

(2) 基本 操作 阶段 。SQL Server 2016 实验 的 第 二 阶段 为 基本 操作 阶段 。 主 要 任务 是 
掌握 Transact-SQL 语言 的 基本 操作 ,包括 SQL 查询 语句 以 及 与 Transact-SQL 语言 相关 的 
视图 .事务 .游标 、 存 储 过 程 . 触 发 器 和 锁 的 基本 操作 ,并 能 够 针对 各 种 数据 库 对 象 在 实际 中 
的 简单 应 用 进行 了 解 。 该 阶段 可 以 针对 教材 的 第 5 一 10 章 内 容 进行 设置 。 

(3) 提高 阶段 。 技 术 提 高 阶段 的 实验 要 求学 生 在 掌握 课本 内 容 的 基础 上 ,自学 一 些 相 
关 知 识 。 技 术 提 高 阶段 的 主要 任务 是 掌握 数据 库 系统 的 设计 与 实现 的 知识 内 容 , 将 理论 知 
识 与 实际 问题 相 结 合 。 该 阶段 可 以 针对 教材 的 第 11 一 15 章 内 容 进行 设置 。 

3. 教学 重点 与 难点 的 处 理 

(1) 可 视 化 工具 的 使 用 。 可 视 化 工具 的 灵活 运用 是 学 习 SQL Server 2016 系统 的 关键 
操作 ,可 视 化 工具 主要 包括 SQL Server Management Studio 中 的 向 导 查询 设计 器 、 工 具 
栏 .菜单 等 。 在 实验 过 程 中 ,有 许多 操作 在 本 质 上 是 相通 的 ,实验 过 程 中 应 该 多 总 结 和 归纳 ， 
“以 益 所 见 , 知 所 不 见 ”。 

(2) Transact-SQL 语句 。SELECT 语句 对 初学 者 来 说 是 比较 复杂 的 ,本 课程 先 介 绍 基 
本 的 内 容 , 即 分 清楚 SELECT、FROM、WHERE、ORDOR、GROUP BY…HAVING INTO 
等 子 句 的 作用 ,再 介绍 复杂 的 嵌 套 查询 语句 ,然后 学 习 与 Transact-SQL 语句 相关 的 内 容 。 

(3) 备份 和 恢复 。 计 算 机 用 户 能 够 对 一 些 重要 文件 .资料 定期 进行 备份 是 必要 的 。 通 
过 恢复 启用 原先 的 文件 备份 ,就 可 以 节省 大 量 的 资源 。 

(4) 权限 管理 。 数 据 库 用 户 访问 到 数据 库 中 的 数据 对 象 是 根据 管理 员 分 配给 他 的 权限 
决定 的 。 不 同 的 用 户 具 有 不 同 的 访问 权限 ,常见 的 访问 权限 有 SELECT 查询 权限 、 
UPDATE 更 新 权限 .INSERT 录入 权限 和 DELETE 删除 权限 。 

(5) 复制 。 复 制 技术 可 以 将 数据 和 数据 库 对 象 从 一 个 数据 库 复制 和 分 发 到 另 一 个 数据 
库 , 然 后 在 数据 库 间 进行 同步 ,以 维持 数据 的 一 致 性 。 

(6) 监视 。 数 据 库 管理 员 可 以 通过 监视 工具 查看 数据 库 系 统 的 运行 情况 ,对 数据 库 进 
行 优化 ,发现 并 修复 错误 。 

通过 实际 操作 和 反复 实践 是 掌握 SQL Server 2016 数据 库 管理 技术 的 必 有 经 之 路 ,也 是 
理解 和 掌握 本 课程 难点 和 重点 、 提 高 自己 创新 能 力 的 重要 方法 。 

4. 上 机 实验 前 的 准备 工作 

上 机 实验 前 的 准备 工作 做 的 好 .可 以 使 得 上 机 实验 得 到 事半功倍 的 效果 。 准 备 工作 至 


少 应 包括 : 

(1) 第 一 次 实验 前 ,教师 需要 向 学 生 说 明 实验 的 整体 要 求 及 实验 的 目标 任务 。 说 明 实 
验 安排 和 进度 ,实验 守则 及 实验 室 安全 制度 。 

(2) 开始 做 实验 就 要 介绍 上 机 操作 的 基本 步骤 ,注意 了 解 SQL Server 2016 实验 过 程 中 
常见 的 错误 ,要 学 会 使 用 联机 从 书 。 

(3) SQL Server 2016 是 理论 与 实验 相 结 合 的 课程 ,上 机 前 应 当先 了 解 相关 的 理论 知 
识 ,再 预习 实验 内 容 、 方 法 和 步骤 ,避免 出 现 边 操作 边 熟 悉 实 验 内 容 的 现象 。 

(4) 该 课程 实验 是 连续 的 整体 ,需要 有 延续 性 。 机 房 应 有 安全 措施 或 学 生 自 己 配 备 
一 些 常用 的 存储 设备 ,避免 前 面 的 实验 数据 和 程序 被 清除 或 改动 影响 后 面 的 实验 操作 
效率 。 

(5) 课 下 多 做 操作 练习 ,如 果 能 结合 实际 课题 进行 训练 ,会 达到 更 好 的 效果 。 

教师 可 以 在 本 实验 内 容 完 成 的 基础 上 ,再 根据 学 生 的 掌握 情况 和 上 机 时 间 的 长 短 指定 
课 后 习题 或 作业 题 作为 实验 内 容 。 本 书 给 出 16 个 实验 ,每 一 次 实验 包括 4 个 以 上 的 操作 模 
块 ,上 机 时 间 每 次 为 2 小 时 左右 。 

5. 学 生 在 实验 过 程 中 应 达到 的 基本 要 求 

一 个 完整 的 SQL Server 2016 实验 的 完成 ,除了 在 掌握 必要 的 理论 基础 上 认真 地 进行 
操作 以 外 ,还 要 记录 好 必要 的 实验 结果 , 养 成 良好 的 习惯 ,进而 完成 实验 报告 。 

(1) 实验 之 前 对 本 实验 对 应 的 理论 内 容 进行 预习 。 

(2) 实验 过 程 中 要 遵守 实验 室 纪律 ,不 做 与 本 实验 无 关 的 事情 。 

(3) 实验 过 程 中 应 及 时 发 现 问题 并 解决 。 

(4) 实验 报告 要 求 按 规定 格式 认真 书写 ,独立 完成 并 按时 上 交 。 

学 习 计 算 机 诸 言 应 该 清楚 这 样 一 个 事实 : 教材 不 可 能 将 软件 的 内 容 介 绍 完全 ,教师 上 
课 也 不 可 能 将 所 有 的 操作 全 部 演示 。SQL Server 2016 中 的 每 一 个 数据 库 对 象 都 可 以 通过 
快捷 菜单 实行 若干 操作 ,可 以 对 应 着 多 种 多 样 的 Transact-SQL 命令 形式 。 在 掌握 命令 格 
式 和 功能 的 基础 上 做 一 些 验证 实验 ,总 结 出 该 操作 的 主要 内 涵 即 可 。 

6. 实验 报告 的 撰写 

根据 实验 内 容 的 记录 整理 出 实验 报告 是 实验 过 程 中 的 一 个 重要 组 成 部 分 。 实 验 报告 的 
格式 要 求 规 范 、 简 洁 、 言 之 有 物 , 以 此 达到 锻炼 学 生 的 文字 表达 能 力 、 提 出 和 发 现 问 题 的 能 
力 ,归纳 和 总 结 的 能 力 的 目的 。 撰 写实 验 报告 ,切忌 养 成 不 加 思考 随意 抄袭 拼凑 一 些 可 有 
可 无 的 内 容 、 编 造 实验 结果 记录 等 坏 习惯 。 

实验 报告 一 般 应 包括 以 下 内 容 : 

(1) 实验 项 目 。 例 如 ,实验 1 认识 SQL Server 2016 的 运行 环境 。 

(2) 实验 目的 。 简 述 本 次 实验 应 该 达到 的 目标 。 

(3) 实验 内 容 。 包 括 操作 步 又 \ 命 令 或 程序 清单 、 中 间 结 果 等 。 

(4) 运行 结果 。 


(5) 总 结 本 次 实验 过 程 中 所 取得 的 经 验 ,分 析 实 验 过 程 中 的 出 错 原因 并 提出 可 能 的 解 | 第 


决 方法 。 


侨 验 北 时 与 实验 内 容 
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18.2 实验 内 容 


实验 1 认识 SQL Server 2016 的 运行 环境 


1. 实验 目的 

(1) 掌握 SQL Server Management Studio 集成 环境 的 构成 和 基本 操作 。 

(2) 熟悉 服务 器 管理 的 基本 操作 。 

(3) 熟悉 联机 丛书 与 教程 的 使 用 。 

2. 实验 预习 与 准备 

预习 主教 材 第 2 章 和 本 书 第 16 章 的 配置 服务 器 选项 部 分 。 

(1) SQL Server Management Studio 集成 环境 的 构成 和 基本 操作 。 

(2) 利用 查询 编辑 器 新 建 查询 。 

(3) SQL Server 2016 的 服务 器 管理 。 

(4) SQL Server 2016 的 联机 丛书 和 教程 。 

3. 实验 内 容 及 步 又 

(1) SQL Server Management Studio 的 启动 和 退出 。 

@ 启动 SQL Server Management Studio。 在 Windows 界面 下 选择 “开始 ”>Microsoft 
SQL Server 2016 Management Studio 命令 。 

@ 连接 服务 器 。 在 弹出 的 “连接 到 服务 器 ”对 话 框 中 的 “服务 器 类 型 "下 拉 列 表 框 中 选 
择 “ 数 据 库 引 擎 ”选项 。“ 服 务 器 名 称 ” 可 由 系统 自动 查找 带 出 ,也 可 在 下 拉 列 表 框 中 选择 “ 浏 
览 更 多 ”, 从 中 查找 可 用 的 本 地 或 网 络 服务 器 。 本 例 中 选择 连接 本 机 的 默认 实例 。 

@ 连接 服务 器 的 属性 设置 。 单 击 “ 连 接 到 服务 器 ”对 话 框 中 的 “选项 ”按钮 ,可 以 对 要 连 
接 的 服务 器 进行 属性 设置 。 本 例 均 采用 默认 设置 。 

@ 身份 验证 。 在 “身份 验证 ?下 拉 列 表 框 中 选择 Windows 身份 验证 ”选项 。 

@) 单 击 “ 连 接 ” 按 钮 后 ,SQL Server Management Studio 将 连接 到 指定 的 服务 器 ,进入 
SQL Server Management Studio 的 初始 界面 。 

@@ 退出 SQL Server Management Studio。SQL Server Management Studio 属于 多 窗 
体 界面 ,退出 该 系统 常见 的 方法 有 两 种 : 单 击 界面 右上 角 的 “关闭 ”按钮 或 选择 “文件 ”一 “ 退 
出 ”命令 均 可 退出 该 系统 。 

(2) SQL Server Management Studio 的 基本 操作 。 

QO@ 菜单 栏 的 操作 。 窗 口 的 菜单 栏 主要 包括 “文件 “编辑 “查询 “工具 ”窗口 “帮助 ” 
等 菜单 项 ,每 项 都 是 一 个 下 拉 菜 单 , 包 含 一 组 常用 的 操作 。 

例如 , 若 要 在 窗口 中 显示 已 注册 的 服务 器 的 相关 信息 , 则 选择 “视图 ”>“ 已 注册 的 服务 
器 ”命令 即 可 打开 该 窗口 。 

若 要 阻止 在 结果 中 返回 显示 受 Transact-SQL 语句 影响 的 行 数 的 消息 , 则 选择 “ 工 
具 ” 一 “选项 ”命令 ,在 弹出 的 “选项 ”对 话 框 中 展开 “查询 执行 ”一 SQL Server 节点 , 单 击 
“高 级 ”按钮 ,选中 SET NONCOUNT 复 选 框 。 

@ 工具 栏 的 操作 。 工 具 栏 将 一 些 常 用 的 操作 图 形 化 ,提高 用 户 的 操作 效率 。 


例如 , 若 要 在 窗口 中 显示 常见 模板 的 相关 信息 , 则 单 击 标准 工具 栏 中 的 “模板 资源 管理 
器 ”按钮 。 

工具 栏 会 随 着 操作 的 进行 而 有 所 变化 , 若 要 在 窗口 中 显示 其 他 工具 栏 ,以 帮助” 工具 栏 
为 例 , 则 选择 “视图 ”一 “工具 栏 " 命 令 .将 “帮助 "菜单 选项 设置 为 选中 状态 即 可 。 

加 “已 注册 的 服务 器 ”窗口 。 该 窗口 显示 数据 库 服 务 器 的 列表 ,也 可 实现 服务 器 的 添加 
和 删除 。SQL Server Management Studio 的 已 注册 服务 器 主要 包括 数据 库 引 擎 、 分 析 服 务 、 
报表 服务 .SQL Server Mobile 和 集成 服务 5 种 类 型 。 单 击 该 窗口 工具 栏 中 的 各 按钮 可 以 切 
换 不 同类 型 的 服务 。 在 此 窗口 中 可 以 看 到 ,系统 自动 注册 了 本 地 服务 器 。 

@ “对象 资 源 管理 器 "窗口 。 系 统 将 所 有 已 连接 的 数据 库 服务 器 及 其 子 对 象 以 树 状 结 
构 显 示 在 该 窗口 中 。 其 中 “数据 库 ” 项 包括 系统 数据 库 、 数 据 库 快照 和 用 户 创建 或 附加 的 数 
据 库 及 其 子 对 象 。 

“对 象 资源 管理 器 ”窗口 工具 栏 中 的 “连接 ”和 “ 断 开 连 接 ” 按 钮 可 实现 SQL Server 
Management Studio 与 指定 服务 的 连接 和 断 开 连接 功能 。 

@ “文档 "窗口 。Transact-SQL 语句 的 编写 、 表 的 创建 ,数据 表 的 展示 和 报表 展示 等 都 
是 在 “文档 "窗口 中 完成 的 。 在 默认 情况 下 将 显示 与 当前 主机 的 数据 库 引 擎 实例 连接 的 “ 摘 
要 ”页 。 查 看 其 中 内 容 的 方式 与 Windows 操作 系统 文件 访问 方式 类 似 ,双击 可 查看 其 子 对 
象 , 单 击 “ 文 档 ” 窗 口 工 具 栏 中 的 “上 移 ” 按 钮 可 返回 上 一 级 。 

@ 属性 窗口 。 该 窗口 主要 用 于 查看 ,修改 对 象 的 属性 。 

@“ 模 板 资源 管理 器 "窗口 。 该 窗口 主要 用 于 实现 查看 和 调用 模板 等 操作 。 

“模板 资源 管理 器 ”窗口 工具 栏 中 的 按钮 可 切换 两 种 不 同 的 请 法 模板 : SQL Server 模 
板 和 Analysis Services 模板 。 

车 要 查看 创建 数据 库 的 语法 模板 ,只 需 展开 “SQL Server 模板 ”下 的 Database 节点 , 双 
击 create database 即 可 。 

(3)“ 新 建 查询 ”操作 。 

| 在 SQL Server Management Studio 中 单 击 工具 栏 上 的 “新 建 查询 ”按钮 ,在 “文档 ” 窗 
口中 打开 查询 编辑 器 代码 窗口 。 

@ 在 查询 编辑 器 中 输入 如 下 Transact-SQL 语句: 

USE master 

SELECT * FROM sysdatabases 


其 中 ,master 为 SQL Server 的 系统 数据 库 , 它 记录 了 SQL Server 系统 的 所 有 系统 信 
息 。sysdatabases 是 master 数据 库 中 的 系统 表 , 该 表 中 记录 了 每 个 系统 数据 库 和 用 户 自 定 
义 数 据 库 的 相关 信息 。 

@ 单 击 工具 栏 中 的 “执行 脚本 ”按钮 ,执行 的 结果 以 网 格 的 形式 显示 在 查询 结果 窗 
口中 。 
(4) 注册 SQL Server 2016 服务 器 。 

对 于 本 地 服务 器 ,一 般 在 安装 后 首次 启动 时 即 可 完成 自动 注册 。 用 户 手动 注册 服务 器 
的 步骤 如 下 : 
@ 在 SQL Server Management Studio 的 工具 栏 中 单 击 “已 注册 的 服务 器 ?按钮 或 选择 
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“视图 ”>“ 已 注册 的 服务 器 ”命令 ,在 窗 体 左 侧 出 现 “ 已 注册 的 服务 器 "窗口 , 右 击 “ 数 据 库 引 
擎 ”选项 ,从 弹出 的 快捷 菜单 中 选择 “新 建 ”>“ 服 务 器 注册 ”命令 。 

@ 弹出 “新 建 服务 器 注册 ”对 话 框 ,切换 至 “常规 ”选项 卡 ,在 “服务 器 名 称 ” 下 拉 列 表 框 
中 输入 或 选择 服务 器 名 称 ,在 “身份 验证 ”下 拉 列 表 框 中 选择 “Windows 身份 验证 ?选项 。 

@ 在 “已 注册 的 服务 器 名 称 ” 文 本 框 中 输入 管理 的 服务 器 名 称 , 可 使 用 默认 的 服务 器 实 
例 名 ,也 可 根据 需要 重 命名 。 

@ 各 项 设置 完成 后 , 单 击 “ 测 试 "按钮 ,出 现 “ 连 接 测 试 成 功 ” 对 话 框 ,表明 可 实现 与 该 服 
务 的 连接 。 单 击 “ 确 定 ” 按 钮 返回 到 “新 建 服务 器 注册 ”对 话 框 。 

@ 在 “新 建 服务 器 注册 ”对 话 框 中 切换 至 “连接 属性 ”选项 卡 ,可 设置 注册 服务 器 默认 连 
接 的 数据 库 、 网 络 协议 等 相关 连接 属性 。 

@ 单 击 “ 保 存 ” 按 钮 即 完成 SQL Server 2016 服务 器 的 注册 操作 。 

(5) 启动 和 停止 SQL Server 2016 服务 器 。 

Q@ 使 用 “SQL Server 配置 管理 器 ”启动 .暂停 和 关闭 服务 器 。 

选择 “开始 ”一 “Microsoft SQL Server 2016 CTP 2.0 配置 管理 器 ”命令 ,打开 SQL 
Server 配置 管理 器 。 在 左边 目录 树 中 选择 “SQL Server 服务 ”, 在 右边 服务 内 容 列表 中 右 击 
服务 名 称 , 在 弹出 的 快捷 菜单 中 选择 “启动 “停止 * 重 新 启动 ”命令 即 可 。 

@) 使 用 SQL Server Management Studio 配置 服务 器 。 

启动 SQL Server Management Studio ,连接 到 SQL Server 服务 器 上 。 在 “对 象 资 源 管 
理 器 "窗口 或 “已 注册 的 服务 器 ”窗口 中 右 击 服务 器 名 ,在 弹出 的 快捷 菜单 中 选择 “启动 “ 停 
止 * 重 新 启动 ”命令 即 可 。 

@ 使 用 SQL Server 服务 启动 和 关闭 服务 器 。 

选择 “开始 -控制 面板 ”~ 系统 和 安全 一 “管理 工具 ”服务 ”命令 ,弹出 “服务 ”对话 
框 , 右 击 服务 名 ,在 弹出 的 快捷 菜单 中 选择 “启动 “停止 “重新 启动 ”命令 即 可 。 

(6) 配置 SQL Server 2016 服务 器 。 

@ 启动 SQL Server Management Studio, 在 "对象 资 源 管理 器 ”窗口 中 右 击 已 连接 的 服 
务 , 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 。 

@ 在 打开 的 “服务 器 属性 ”对 话 框 中 可 以 实现 对 于 SQL Server 2016 服务 器 的 配置 。 该 
对 话 框 中 包含 “常规 “内 存 ”“ 处 理 器 ”“ 安 全 性 “连接 ”数据库 设 置 "“ 高 级 “权限 ”等 选 
项 卡 。 

4. 实验 报告 总 结 

(1) SQL Server 客户 端 和 服务 器 端 组 件 的 功能 。 

(2) SQL Server Management Studio 集成 环境 的 构成 和 基本 操作 。 

(3) SQL Server 2016 服务 器 的 配置 。 


实验 2 数据 库 的 创建 与 管理 


1. 实验 目的 

(1) 掌握 数据 库 的 基本 概念 和 存储 方式 。 
(2) 掌握 创建 、 修 改 数据 库 的 方法 。 

(3) 掌握 管理 数据 库 的 方法 。 


2. 实验 预习 与 准备 

主教 材 第 3 章 。 

(1) 数据 库 的 基本 概念 和 存储 方式 。 

(2) 利用 SQL Server Management Studio 和 TransactrSQL 语句 创建 、 修 改 数据 库 。 

(3) 利用 SQL Server Management Studio 和 TransactrSQL 语句 管理 数据 库 。 

(4) 文件 组 的 创建 与 管理 。 

3. 实验 内 容 及 步 又 

(1) 利用 SQL Server Management Studio 创建 一 个 名 为 employees 的 数据 库 。 该 数据 
库 的 主 数据 文件 逻辑 名 称 为 employees, 初 始 大 小 为 10MB, 最 大 尺寸 为 无 限 大 ,增长 速度 为 
10%; 数据 库 的 日 志文 件 逻 辑 名 称 为 employees_log, 初 始 大 小 为 1MB, 最 大 尺寸 为 5MB， 
增长 速度 为 1MB。 存 放 路 径 为 “D:\DATA\”, 其 他 均 采 用 默认 设置 。 

@ 启动 SQL Server Management Studio, 在 “资源 管理 器 ”窗口 右 击 “ 数 据 库 ” 选 项 ,在 
弹出 的 快捷 菜单 中 选择 “新 建 数 据 库 ” 命 令 。 

@ 在 打开 的 “新 建 数据 库 " 窗 口中 选择 “常规 ”选项 卡 。 在 “数据 库 名 称 ” 文 本 框 中 输入 
数据 库 名 称 employees。 在 “数据 库 文件 列表 中 可 更 改 主 数据 文件 及 事务 日 志文 件 的 默 
认 值 。 

@@ 单 击 数据 文件 所 在 行 , 在 “初始 大 小 ”文本 框 中 输入 10 , 单 击 “自动 增长 "文本 框 中 的 
按钮 ,出 现 “ 更 改 employees 的 自动 增长 设置 ”对话 框 ,在 “文件 增长 ”选项 组 中 选择 “ 按 MB” 
单 选 按钮 ,设置 文件 增长 速度 为 1MB, 在 “最 大 文件 大 小 ”选项 组 中 选择 “不 限制 文件 增长 ” 
单 选 按钮 。 设 置 完 成 后 单 击 “ 确 定 ” 按 钮 ,返回 “新 建 数 据 库 ”窗口 ,在 路径” 文本 框 中 输入 或 
单 击 按钮 选择 路 径 *“D:\DATA\”。 

@ 单 击 事务 日 志文 件 所 在 行 ,在 “初始 大 小 ”文本 框 中 输入 1, 单 击 “ 自 动 增长 ”文本 框 中 
的 按钮 ,出 现 “ 更 改 employees_log 的 自动 增长 设置 ”对话 框 ,在 “文件 增长 ”选项 组 中 选择 
“ 按 百 分 比 ” 单 选 按钮 ,设置 文件 增长 速度 为 10%。 在 “最 大 文件 大 小 ”选项 组 中 选择 “限制 
文件 增长 ” 单 选 按 钮 ,设置 文件 最 大 尺寸 为 5MB。 设 置 完 成 后 单 击 “ 确 定 ” 按 钮 ,返回 “新 建 
数据 库 ? 窗 口 ,在 "路径" 文 本 框 中 输入 或 单 击 按钮 选择 路 径 *D:\DATA\”。 

@ 在 “新 建 数 据 库 ” 窗 口中 的 “选项 ”及 “文件 组 ”选项 卡 中 均 采用 默认 设置 。 

@ 单 击 “ 确 定 ” 按 钮 即 完成 了 创建 数据 库 employees 的 操作 。 

(2) 利用 SQL Server Management Studio 添加 次 要 数据 文件 employee2 和 事务 日 志文 
件 employees2_log。 

@ 启动 SQL Server Management Studio, 在 “资源 管理 器 ”窗口 中 右 击 employees 数据 
库 , 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ,在 打开 的 “数据 库 属性 ”窗口 中 选择 “文件 ” 选 
项 卡 。 

@ 增加 数据 文件 。 单 击 “ 添 加 ”按钮 ,在 “数据 库 文件 "列表 中 将 新 增 一 项 。 在 “人 逻辑 名 
称 ” 文 本 框 中 输入 employee2, 在 “文件 类 型 "下 拉 列 表 框 中 选择 “数据 ”选项 。 

@ 在 “文件 组 ”下 拉 列 表 框 中 选择 “新 文件 组 ”选项 ,出 现 “employees 的 新 建文 件 组 ”对 
话 框 ,在 “名 称 ”文本 框 中 输入 文件 组 名 称 MYGROUP, 单 击 “ 确 定 ” 按 钮 ,返回 “数据 库 属性 ” 
窗口 。 

@ 在 “初始 大 小 ”文本 框 中 输入 20, 单 击 “ 自 动 增长 "文本 框 中 的 按钮 , 出现“ 更 改 
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employees2 的 自动 增长 设置 ”对话 框 ,在 “文件 增长 ”选项 组 中 选择 “ 按 百 分 比 ” 单 选 按钮 , 设 
置 文件 增长 速度 为 20% 。 在 “最 大 文件 大 小 ?选项 组 中 选择 “限制 文件 增长 " 单 选 按钮 ,设置 
文件 最 大 尺寸 为 100MB。 设 置 完 成 后 单 击 “确定 ”按钮 ,返回 “数据 库 属性 ”窗口 。 

在 “路 径 ” 文 本 框 中 输入 或 单 击 按钮 选择 路 径 *“D:\DATA\”。 

@@ 增加 日 志文 件 。 单 击 “ 添 加 ”按钮 ,在 “数据 库 文件 ”列表 中 将 新 增 一 项 。 在 “逻辑 名 
称 ” 文 本 框 中 输入 employee2_log, 在 “文件 类 型 "下 拉 列 表 框 中 选择 “日 志 ” 选 项 ,其 他 设置 均 
保持 默认 值 。 

@ 在 “数据 库 属性 "窗口 的 “选项 ”选项 卡 中 可 修改 数据 库 的 相关 选项 。 在 “排序 规 
则 ”下 拉 列 表 框 中 选择 Chinese _PRC_CS_AI 选 项 ,可 使 得 在 排序 过 程 中 区 分 大 小 写 。 
由 于 该 数据 库 对 于 性 能 要 求 高 但 安全 性 要 求 较 低 , 在 “恢复 模式 ”下 拉 列 表 框 中 选择 
“简单 ”选项 。 

在 “其 他 选项 ”区 域 中 的 “状态 ”选项 组 中 设置 限制 访问 ”下拉 列 表 框 为 restricted， 
使 其 只 有 db_owner( 数 据 库 所 有 者 ) .dbcreator( 数 据 库 创 建 者 ) 和 sysadmin( 系 统管 理 员 ) 
这 三 种 角色 才能 访问 数据 库 ,保证 系统 安全 性 。 

单 击 “ 确 定 ” 按 钮 , 即 完成 了 修改 数据 库 employees 的 操作 。 

(3) 利用 Transact-SQL 语句 创建 数据 库 test, 采 用 默认 参数 。 若 该 数据 库 已 存在 , 则 
删除 后 重建 。 

在 查询 编辑 器 中 输入 如 下 代码 并 执行 : 

USE master 

G0 

IF EXISTS(SELECT * FROM sysdatabases WHERE name = 'test') 

DROP DATABASE test 

CREATE DATABASE test 

系统 将 默认 在 SQL Server 2016 安装 路 径 MSSQL10_50. MSSQLSERVER\MSSQL\ 
DATA 文件 夹 下 创建 数据 文件 test. MDF 和 事务 日 志文 件 test_log. LDF。 

(4) 修改 数据 库 test, 将 数据 文件 的 钠 辑 文件 名 修改 为 “测试 数据 ”, 操 作 系 统 文件 名 修 
改 为 “D:\DATA\test. MDF”。 将 事务 日 志文 件 的 逻辑 文件 名 修改 为 “测试 数据 日 志 ”, 操 作 
系统 文件 名 修改 为 “D:\DATA\test_log. LDF”。 并 且 为 数据 库 新 增 一 个 逻辑 名 称 为 “测试 
数据 2” 的 次 要 数据 文件 。 

@ 在 “查询 编辑 器 ”中 输入 如 下 代码 并 执行 ， 

ALTER DATABASE test 

MODIFY FILE( NAME = test, NEWNAME = 测试 数据 ,， 

FILENAME = 'D:\DATA\test. MDF' ) 

ALTER DATABASE test 

MODIFY FILE( NAME = test_log, NEWNAME = 测试 数据 日 志 ， 


FILENAME = 'D:\DATA\test_log. LDF') 
G0 


系统 给 出 如 下 提示 信息 : 


文件 'test' 在 系统 目录 中 已 修改 。 新 路 径 将 在 数据 库 下 次 启动 时 使 用 。 
文件 名 称 ' 测 试 数据 ' 已 设置 。 


文件 'test_log' 在 系统 目录 中 已 修改 。 新 路 径 将 在 数据 库 下 次 启动 时 使 用 。 

文件 名 称 测试 数据 日 志 ' 已 设置 。 

@ 将 数据 库 test 设置 为 脱 机 状态 (Set databae Offline) 。 

在 SQL Server Management Studio 中 选择 展开 “资源 管理 器 ”>“ 数 据 库 ” 子 目录 , 右 击 
test 数据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “ 脱 机 ”命令 ,或 者 在 查询 编辑 器 中 输入 
ALTER DATABASE test SET OFFLINE。 

@ 将 文件 实际 移 至 新 目录 中 。 将 数据 文件 test. MDF 和 事务 日 志文 件 test_log. LDF 
移 至 “D:\DATA\” 文 件 夹 下 。 

@ 将 数据 库 test 重新 设置 为 联机 状态 (Set database back online) 。 

在 SQL Server Management Studio 中 选择 展开 “资源 管理 器 ”一 “数据 库 ”, 布 击 test 数 
据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”>“ 联 机 ”命令 。 或 者 在 查询 编辑 器 中 输入 ALTER 
DATABASE test SET ONLINE。 

@) 在 查询 编辑 器 中 输入 如 下 添加 次 要 数据 文件 的 代码 并 执行 : 

ALTER DATABASE test 

ADD FILE 

( NAME = 测试 数据 , 

FILENAME = 'D:\DATA\test2. NDF', 
SIZE = 10MB, 
MAXSIZE = 50MB, 


FILEGROWTH = 10 % 


可 以 在 SQL Server Management Studio 中 右 击 数据 库 test, 在 弹出 的 快捷 菜单 中 选择 
“属性 ”命令 ,打开 “数据 库 属性 ”窗口 ,查看 数据 库 的 修改 情况 。 

(5) 利用 SQL Server Management Studio 将 test 数据 库 分 离 后 重新 附加 到 当前 SQL 
Server 实例 中 。 

@ 分 离 数据 库 。 启 动 SQL Server Management Studio ,展开 “资源 管理 器 ”数据库 ? 
子 目录 , 右 击 test 数据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “分离 "命令, 出现“ 分 离 数 据 
库 ” 对 话 框 , 单 击 “ 确 定 ” 按 钮 , 即 完成 了 分 离 数 据 库 的 操作 。 

@ 附加 数据 库 。 启 动 SQL Server Management Studio ,展开 * 资 源 管 理 器 ” 子 目 录 , 右 
击 “ 数 据 库 ? 选 项 ,在 弹出 的 快捷 菜单 中 选择 * 附 加 ”命令 出现“ 附加 数据 库 ? 对 话 框 , 单 击 “ 添 
加 ”按钮 ,弹出 “定位 数据 库 文件 ”对 话 框 ,从 中 定位 要 添加 的 数据 库 的 主 数 据 文件 , 即 定位 
“D:\DATA\test. MDF”, 单 击 “ 确 定 ” 按 钮 。 返 回 到 “附加 数据 库 ” 对 话 框 , 单 击 “ 确 定 ” 按 钮 ， 
即 完成 了 附加 数据 库 的 操作 。 

(6) 利用 Transact-SQL 语句 将 test 数据 库 重 命名 为 “测试 ,调用 系统 存储 过 程 将 * 测 
试 ? 重 命名 为 test。 

g@ 在 查询 编辑 器 中 输入 如 下 重 命名 数据 库 的 Transact-SQL 代码 并 执行 : 


RLTER DATABASE test 
MODIFY NAME = 测试 


系统 给 出 “数据 库 名 称 ' 测 试 ' 已 设置 ”的 提示 信息 。 
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@@ 在 查询 编辑 器 中 输入 如 下 调用 系统 存储 过 程 的 代码 并 执行 : 
sp_renamedb ' 测 试 ', 'test' 


系统 给 出 “数据 库 名 称 'test' 已 设置 ”的 提示 信息 。 
(7) 利用 Transact-SQL 语句 删除 创建 的 数据 库 employees 和 test。 
在 查询 编辑 器 中 输入 如 下 程序 代码 并 执行 : 


DROP DATABASE employees, test 


4. 实验 报告 总 结 
(1) 文件 组 和 事务 日 志文 件 的 作用 。 
(2) 创建 数据 库 的 默认 路 径 和 默认 设置 。 


实验 3 表 的 创建 与 管理 


1. 实验 目的 

(1) 掌握 系统 数据 类 型 的 特点 和 功能 。 

(2) 掌握 创建 、 修 改 表 结构 的 方法 。 

(3) 掌握 插入 、 更 新 和 删除 表 数 据 的 方法 。 

2. 实验 预习 与 准备 

主教 材 第 4 章 4.1.4.2 节 。 

(1) SQL Server 2016 的 系统 数据 类 型 。 

(2) 表 结构 的 创建 ,修改 和 删除 。 

(3) 表 数 据 的 浏览 ,插入 、 更 新 和 删除 。 

3. 实验 内 容 及 步 又 

(1) 利用 Transact-SQL 语句 创建 数据 库 teaching, 存 放 路 径 为 “D:\DATA\”, 其 他 均 
采用 默认 设置 。 若 该 数据 库 已 存在 , 则 删除 后 重建 。 

在 查询 编辑 器 中 输入 如 下 创建 数据 库 的 代码 并 执行 : 

USE master 

GO 

IF EXISTS(SELECT * FROM sysdatabases WHERE name = 'teaching') 

DROP DATABASE teaching 

CREATE DATABASE teaching 

ON(NAME = teaching, FILENAME = 'D:\DATA\teaching. MDF') 

LOG ON( NAME = teaching_log, FILENAME = 'D:\DATA\teaching_log. LDF') 

(2) 利用 SQL Server Management Studio 在 teaching 数据 库 中 创建 表 student, 表 结构 
如 表 18-1 所 示 。 


表 18-1 student 表 结 构 


列 序号 列 名 类 型 取 值 说 明 是 否 主键 列 含义 
1 studentno nchar(11) NOT NULL 是 学 生 学 号 
2 sname nchar(8) NULL 否 学 生 姓名 
3 sex nchar(2) NULL 否 性 别 


列 序号 列 名 类 型 取 值 说 明 是 否 主键 列 含义 
4 birthdate date NULL 否 出 生日 期 
5 classno nchar(6) NULL 否 班级 编号 
6 point smallint NULL 否 入 学 成 绩 
7 phone nchar(12) NULL 否 电话 
8 Email nvarchar(20) NULL 否 电子 信箱 


@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”一 “数据 库 ” 一 teaching 子 
目录 , 右 击 “ 表 ” 选 项 ,在 弹出 的 快捷 菜单 中 选择 “新 建 表 ” 命 令 。 

@ 在 弹出 的 “ 表 设计 器 "窗口 中 依次 输入 列 名 ,数据 类 型 及 允许 空 否 等 选项 。 

@ 布 击 studentno 列 , 在 弹出 的 快捷 菜单 中 选择 “设置 主键 "命令 ,或 者 单 击 “设置 主键 ” 
按钮 用 于 设置 主键 。 

@ 设置 完毕 后 单 击 “ 保 存 ” 按 钮 ,在 弹出 的 对 话 框 中 输入 表 名 student, 单 击 “ 确 定 ” 按 
钮 , 即 完成 了 创建 表 的 操作 。 

(3) 利用 Transact-SQL 语句 在 teaching 数据 库 中 创建 数据 表 。 

@ 创建 course 表 的 结构 : 

CREATE TABLE course ( courseno nchar (6) NOT NULL, cname nchar(20) NULL, type nchar (8) NULL, 


period tinyint NULL, experi tinyint NULL, term tinyint NULL, CONSTRAINT PK_course PRIMARY KEY 
(courseno)) 


@ 创建 score 表 的 结构 : 


CREATE TABLE score( studentno nchar (11) NOT NULL, courseno nchar(6) NOT NULL, daily numeric(6, 
2) NULL, final numeric(6, 2) NULL, CONSTRAINT PK_score PRIMARY KEY( studentno, courseno) ) 


@ 创建 teacher 表 的 结构 : 


CREATE TABLE teacher(teacherno nchar(6) NOT NULL PRIMARY KEY, tname nchar(8) NULL, major nchar 
(10) NULL, prof nchar(10) NULL, department nchar(12) NULL) 


@ 创建 class 表 的 结构 : 


CREATE TABLE class(classno nchar(7) NOT NULL PRIMARY KEY, classname nchar(12) NULL, department 
nchar(12) NULL, monitor nchar(8) NULL) 


@ 创建 teach_class 表 的 结构 : 

CREATE TABLE teach_class (teacherno nchar (6) NOT NULL, classno nchar(7) NOT NULL, courseno 

nchar(6) NOT NULL, CONSTRAINT PK_teach class PRIMARY KEY(teacherno, classno, courseno)) 

(4) 利用 SQL Server Management Studio 为 数据 表 输 入 数据 。 

@ 为 student 表 输 入 数据 。 启 动 SQL Server Management Studio, 展开“ 资源 管理 
器 "一 数据库 ”一 teaching 子 目录 , 布 击 student 表 , 在 弹出 的 快捷 菜单 中 选择 “编辑 表 前 
200 行 ”命令 。 

@ 进入 数据 输入 界面 ,依次 按照 表 结 构 的 要 求 为 每 一 列 输入 数据 。 每 输 完 一 行 ,系统 
会 自动 进入 下 一 行 的 输入 状态 。 在 此 过 程 中 要 针对 不 同 的 数据 类 型 输入 合法 有 效 的 数据 。 
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@ 对 student 表 输 入 数据 完毕 , 单 击 “ 保 存 ” 按 钮 。 

@ 对 其 他 表 的 输入 过 程 类 似 。 

student、course、score, teacher class teach_class 表 中 输入 的 数据 分 别 如 图 18-1 一 
图 18-6 所 示 。 


re 
studentno sname sex birthdate dlassno point phone Email 
17111133071 。 崔 岩 坚 男 1998-06-06 170601 787 15556845645 。 cui@126com 
|17112100072 这 到 远 男 1999-02-04 = 170501 658 12545678998 su12@163.com 
17112111208 。 区 秋 男 1997-02-14 = 170601 666 15878945612 han@163.com 
117122203567 。 到 沼 女 1999-09-09 = 170601 898 13245674564 。 jiao@126com 
| 17123567897 。 起 驴 欣 女 1999-08-04 170501 999 13175689345 。 pingan@163.com 
|17126113307 。 性 云 泽 女 2000-09-07 170601 787 13245678543 。 zhu@163.com 
|18122210009 许 海 冰 男 2000-11-05 180501 789 13623456778 qwe@163.com 
118122221324 ”人 女 2000-12-04 180501 879 13178978999 。 aaa@sinacom 
| 18125111109 。 硕 条 展 男 2001-03-01 。 180801 789 15678945623 。 jing@sinacom 
》 “|18125121107 。 梁 欣 女 2001-09-03 180502 777 13145678921 。 bing@126com 
| 18135222201 。 政文 昌 女 2002-10-06 180502 867 15978945645 。 tang@163.com 
| 18137221508 。 赵 望 寻 女 2001-02-13 180802 789 12367823453 。 ping@163.com 
| 18282610019 。 孙 释 远 女 1999-09-09 180512 777 1328909876 sdqd@163.com 
.NW NULL NUL NULL NULL NUL NULL NULL 


图 18-1 student 表 数 据 


LG37CEYPE9YWCS..ng - dbo.course Xx 
courseno _ name type period experi _ term 

» EE 高 等 数学 必 收 64 16 2 
c05109 (语言 必修 48 16 2 
c05127 数据 结构 必修 54 16 日 
c05129 数据 库 应 用 与 开发 ”… 必修 64 16 5 
c05138 软件 工程 远 修 48 8 5 
c05139 统一 建 模 滞 言 UML .选修 48 16 6 
c05141 WIN 程 序 设计 选修 64 16 7 
c05142 WEB 程 序 设计 “ 选 禾 64 16 7 
c06108 机 械 制 图 必修 64 8 2 
c06127 机 械 没 计 必修 64 8 3 
c06172 铸造 工艺 选修 48 16 6 
c08106 经 济 法 必修 48 0 7 
c08123 全 融 字 必修 40 0 5 
c08171 会 计 软 件 选修 32 8 8 

.NULL NULL NUL NULL NUL NULL 


图 18-2 course 表 数 据 


(4) 利用 Transact-SQL 语句 修改 表 结 构 。 

@ 为 student 表 增 加 民族 nation 列 ,数据 类 型 为 nchar(10) ,人 允许 为 空 。 

USE teaching 

GO 

ALTER TABLE student 

ADD nation nchar(10) NULL 

GO 

注意 , 当 数据 表 中 已 经 存在 数据 , 则 新 增 的 列 在 不 带 默认 值 约束 的 情况 下 不 能 规定 为 非 
空 。 若 将 上 述 代码 中 的 NULL 修改 为 NOT NULL, 则 系统 给 出 如 下 错误 提示 信息 : 


LG37CEYPE9YWCSG.-ing - dbo.score Xx 

studentno courseno daily 

[17123567897  c05103 85.00 77.00 
17123567897 。 c06127 99.00 99.00 
17126113307 ”<05127 93.00 87.00 
17126113307 。 c06108 66.00 82.00 
17126113307 co8171 88.00 79.00 
18122210009 。 c05103 87.00 82.00 
18122210009 。 c05109 77.00 91.00 
18122221324 。 c05103 88.00 62.00 
18122221324 。 c05109 91.00 77.00 
18125111109 。 c08106 79.00 99.00 
18125111109 。 c08123 85.00 92.00 
18125111109 。 c08171 77.00 92.00 
18125121107 。” c05103 7400 91.00 
18125121107 。 05109 89.00 60.00 


18-3 score 表 数 据 


LG37CEYPE9YWCS...g - dboteacher X 
| teacherno tname maior prof department 

» WE 韩 寺 和 软件 工程 教 摇 计算 机 学 院 
t05002 张 衣 新 全 融 助教 农机 字 院 
t05003 mt 硼 网 络 技术 教授 计算 机 学 院 
t05011 海 圭 计算 机 设计 副教授 计算 机 学 院 
105017 户 明 欣 软件 测 坛 讲师 计算 机 学 院 
105039 张 世 月 计算 机 应 用 5 授 计算 机 学 院 
t06011 刘海 悦 机 械 制造 教授 机 械 学 院 
106023 娠 思 远 铸造 工艺 副教授 机 械 学 院 
t07019 纪要 入 经 济 管理 讲师 管理 学 院 
108017 田 有 余 金融 管理 副教授 管理 字 院 

. NULL NULL NULL NULL NULL 


图 18-4 ”teacher 表 数 据 


LG37CEYPE9YWCS...dbo.teach_class x 


teacherno dlassno courseno 
» | 本 而 170501 c05109 
105002 170501 c05127 
105003 180501 c05127 
105011 180502 c05138 
105017 180501 c05127 
t06011 170601 c06127 
106023 170601 c06172 
107019 180801 c08123 
t08017 180801 c08106 
» IN NULL NULL 


图 18-6 ”teach_class 表 数 据 


地 驯 典 
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消息 4901, 级 别 16, 状态 1, 第 2 行 


ALTER TABLE 只 允许 添加 满足 下 述 条 件 的 列 : 列 可 以 包含 空 值 ; 或 者 列 具 有 指定 的 
DEFAULT 定义 ; 或 者 要 添加 的 列 是 标识 列 或 时 间 戳 列 ; 或 者 ,如 果 前 几 个 条 件 均 未 满足 ， 
则 表 必 须 为 空 以 允许 添加 此 列 。 不 能 将 列 snation 添加 到 非 空 表 student 中 ,因为 它 不 满足 
上 述 条 件 。 

@ 修改 student 表 中 nation 列 的 数据 类 型 为 varchar(10) 。 


ALTER TABLE student 
ALTER COLUMN nation varchar(10) 


@ 删除 student 表 中 的 nation 列 。 


ALTER TABLE student 
DROP COLUMN nation 


(5) 利用 Transact-SQL 语句 修改 表 中 数据 。 
@ 向 student 表 中 插入 一 条 学 生 记 录 。 
USE teaching 
G0 
INSERT INTO student 
VALUES ('18122221326'，' 李 杰 '，' 男 ，'1999 - 2-3', '180501', 754, '13456734522', '1ijie@sina. com 
') 
当 数 据 值 列表 与 列 名 表 中 的 列 名 次 序 一 致 .个 数 相等 .数据 类 型 一 一 对 应 时 , 列 名 表 可 
以 省 略 。 
@ 向 score 表 中 插入 一 条 选课 记录 。 
INSERT INTO score( studentno, courseno) 
VALUES ('18122221326', 'c05109') 
列 名 表 中 没有 出 现 的 属性 列 , 新 插入 的 记录 在 这 些 列 上 将 取 空 值 。 该 记录 中 daily 和 
final 列 的 取 值 均 为 NULL。 
@ 将 student 表 中 插入 的 学 号 为 18122221326 的 学 生性 别 修改 为 女 ”。 
UPDATE student 
SET sex = ' 女 ' 
WHERE studentno = '18122221326' 
如 果 省 略 WHERE 子 句 , 则 表示 要 修改 表 中 的 所 有 记录 。 
@ 删除 学 号 为 18122221326 学 生 的 基本 信息 和 选课 信息 。 
DELETE FROM student 
WHERE studentno = '18122221326' 


DELETE FROM score 
WHERE studentno = '18122221326 


4. 实验 报告 总 结 
(1) 常用 字符 数据 类 型 的 功能 和 区 别 。 


(2) 修改 表 结 构 对 表 中 记录 的 影响 。 
(3) 表 结 构 和 表 数 据 修改 的 方法 。 


实验 4 数据 完整 性 与 数据 传输 


1. 实验 目的 

(1) 掌握 数据 完整 性 的 类 型 和 概念 。 

(2) 掌握 创建 、 修 改 约束 的 方法 。 

(3) 掌握 利用 Transact-SQL 语句 创建 、 维 护 规则 和 默认 值 对 象 的 方法 。 

(4) 掌握 利用 SQL Server 导入 导出 向 导 实现 数据 的 导入 和 导出 。 

2. 实验 预习 与 准备 

主教 材 4. 3 一 4.5 节 , 本 书 第 4 章 。 

(1) 数据 完整 性 的 类 型 和 实现 机 制 。 

(2) 约束 、 规 则 和 默认 值 对 象 的 创建 和 修改 。 

(3) 数据 的 导 和 人 和 导出 。 

3. 实验 内 容 及 步 又 

(1) 利用 SQL Server Management Studio 将 teaching 数据 库 中 score 表 的 courseno 列 
设置 为 引用 表 course 的 外 键 。 

@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”一 “数据 库 ” 一 teaching 数 
据 库 一 “ 表 ” 子 目录 , 右 击 score 表 , 在 弹出 的 快捷 菜单 中 选择 “设计 ”命令 。 

@ 出 现 “ 表 设计 器 ”窗口 ,选择 “ 表 设 计 器 ”一 “关系 ”命令 。 

@ 弹出 “外 键 关系 ”对 话 框 , 单 击 “ 添 加 ”按钮 ,在 “常规 ”选项 组 中 单 击 “ 表 和 列 规范 ” 文 
本 框 后 的 按钮 。 

@ 在 弹出 的 “ 表 和 列 ? 对 话 框 中 选择 主键 表 course 和 外 键 表 score 及 共有 的 列 
courseno。 单 击 “ 确 定 ” 按 钮 ,返回 “外 键 关系 ”对 话 框 。 

@ 在 “标识 ”选项 组 的 “名 称 ” 文 本 框 中 输入 外 键 名 称 FK_score_course。 单 击 “ 关 闭 ” 按 
钮 ,返回 到 “ 表 设 计 器 "窗口 , 单 击 “ 保 存 " 按 钮 ,外 键 约束 创建 完毕 。 

(2) 利用 Transact-SQL 语句 将 teaching 数据 库 中 score 表 中 的 studentno 列 设置 为 引 
用 表 student 的 外 键 。 将 teach_class 表 中 的 teacherno、classno 和 courseno 列 分 别 设置 为 
引用 表 teacher class 和 course 的 外 键 。 

在 “查询 编辑 器 ”中 输入 如 下 创建 外 键 约 束 的 代码 并 执行 : 


USE teaching 

GO 

ALTER TABLE score 

ADD CONSTRAINT FK_score student FOREIGN KEY ( studentno) 
REFERENCES student( studentno) 

GO 

ALTER TABLE teach class 

ADD CONSTRAINT FK_ teacher FOREIGN KEY (teacherno) 
REFERENCES teacher(teacherno) 

GO 

ALTER TABLE teach _ class 
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RDD CONSTRAINT FK class FOREIGN KEY (classno) 

REFERENCES class(classno) 

GO 

ALTER TABLE teach class 

RDD CONSTRAINT FK course FOREIGN KEY (courseno) 

REFERENCES course(courseno) 

(3) 利用 SQL Server Management Studio 为 teaching 数据 库 中 class 表 的 classname 
创建 UNIQUE 约束 。 

@ 启动 SQL Server Management Studio ,展开 “资源 管理 器 ”一 “数据 库 ” 一 teaching 数 
据 库 一“ 表 ? 子 目录 , 右 击 class 表 , 在 弹出 的 快捷 菜单 中 选择 “设计 ”命令 。 

@ 出 现 “ 表 设计 器 ”窗口 , 单 击 工具 栏 上 的 “管理 索引 和 键 ” 按 钮 。 

@ 弹出 “索引 / 键 ”对 话 框 , 单 击 “ 添 加 ”按钮 ,在 “常规 ”选项 组 的 “类 型 "下 拉 列 表 框 中 选 
择 “ 唯 一 键 ” 选 项 , 单 击 “ 列 ”文本 框 后 的 按钮 。 

@ 在 弹出 的 “索引 列 ? 对 话 框 中 选择 创建 此 索引 的 列 名 为 classname 和 排序 顺序 为 升 
序 。 单 击 “ 确 定 ” 按 钮 ,返回 到 “索引 / 键 "对 话 框 。 

@ 在 “常规 ”选项 组 的 “是 唯一 的 "下 拉 列 表 框 中 选择 是”。 在 “标识 "选项 组 的 “名 称 ” 
文本 框 中 输入 UNIQUE 约束 名 称 UQ_classname。 单 击 “ 关 闭 ” 按 钮 ,返回 到 “ 表 设 计 器 ” 窗 
口 , 单 击 “ 保 存 ” 按 钮 ,UNIQUE 约束 创建 完毕 。 

@ 执行 如 下 插入 语句: 

INSERT INTO class 

VALUES( '180602', ' 计 算 机 1802', ' 计 算 机 学 院 ', ' 马 文 韭 ') 

由 于 创建 了 UNIQUE 约束 UQ_classname, 当 插入 和 更 新 记录 时 所 有 “班级 名 称 ” 不 符 
合 条 件 的 记录 无 法 实现 操作 ,并 显示 错误 提示 信息 : 

消息 2601, 级 别 14, 状态 1, 第 1 行 

不 能 在 具有 唯一 索引 'UQ_classname' 的 对 象 'dbo. class 中 插 人 重复 键 的 行 。 

语句 已 终止 。 

(4) 利用 TransactrSQL 语句 为 teaching 数据 库 中 course 表 的 cname 列 和 period 列 的 
组 合 创 建 UNIQUE 约束 ,规定 相同 学 时 课程 名 的 唯一 性 。 

ALTER TABLE course 

ADD CONSTRAINT UQ_course UNIQUE( cname, period) 

(5) 利用 SQL Server Management Studio 为 teaching 数据 库 中 student 表 的 birthdate 
列 创建 CHECK 约束 ,规定 学 生 的 年 龄 在 17 一 25 岁 。 

@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”一 “数据 库 ” 一 teaching 数 
据 库 一 “ 表 ” 子 目录 , 右 击 student 表 , 在 弹出 的 快捷 菜单 中 选择 “设计 ”命令 。 

@ 出 现 “ 表 设 计 器 "窗口 , 单 击 工具 栏 上 的 “管理 CHECK 约束 "按钮 。 

@ 弹出 *CHECK 约束 ”对 话 框 , 单 击 “ 添 加 ”按钮 ,在 “常规 ”选项 组 中 单 击 “ 表 达 式 ” 文 
本 框 后 的 按钮 。 

@ 在 弹出 的 “CHECK 约束 表达 式 ” 对 话 框 中 输入 表达 式 “YEAR (GETDATE()) - 
YEAR(birthdate) BETWEEN 17 AND 25”。 单 击 “ 确 定 ” 按 钮 ,返回 到 “CHECK 约束 ” 


@ 在 “标识 ?选项 组 的 “名 称 ? 文 本 框 中 输入 CHECK 约束 名 称 CK_student_birthdate。 


单 击 “ 关 


闭 ” 按 钮 ,返回 到 “ 表 设 计 器 "窗口 , 单 击 “ 保 存 ” 按 钮 ,CHECK 约束 创建 完毕 。 


@ 执行 如 下 插入 语句 : 


INSERT INTO student( studentno, sname, sex, birthdate, classno) 
VALUES( '18122221328', ' 张 源 ', ' 男 ', '1995 -04 一 05', '180501') 


由 村 
期 "不 符 


F 创建 了 CHECK 约束 CK_student_birthdate, 当 插入 和 更 新 记录 时 所 有 “出 生日 
合 条 件 的 记录 无 法 实现 操作 ,并 显示 错误 提示 信息 : 


消息 547, 级别 18, 状态 0, 第 1 行 
INSERT 语句 与 CHECK 约束 "CK_student_birthdate" 冲突 .该 冲突 发 生 于 数据 库 "teaching", 表 "dbo. 
student", column 'birthdate'. 


语句 已 终止 。 


(6) 
东 , 规 定 


利用 Transact-SQL 语句 为 teaching 数据 库 中 course 表 的 term 列 创建 CHECK 约 
学 期 的 取 值 范围 为 1 一 12。 


ALTER TABLEcourse 


ADD 


(7) 


CONSTRAINT CK_term CHECK(term>= 1 AND term<= 12) 


利用 Transact-SQL 语句 删除 teaching 数据 库 中 的 约束 UQ_classname、UQ_ 


course,CK_student_birthdate 和 CK_term。 


ALTER TABLE student 

DROP CONSTRAINT CK_student birthdate 
ALTER TABLE course 

DROP CONSTRAINT UQ_course, CK_term 
ALTER TABLE class 

DROP CONSTRAINT UQ_classname 


(8) 
只 能 为 “ 


利用 Transact-SQL 语句 为 teaching 数据 库 创 建 规则 prof_rule, 规 定 教师 职称 取 值 
助教 “讲师 “副教授 ”和 “教授 ”, 并 将 其 绑 定 到 teacher 表 的 prof 列 上 。 


OO 在 teaching 数据 库 中 创建 规则 prof_rule。 
CREATE RULE prof_rule AS @prof IN (' 助 教 ', ' 讲 师 ', ' 副 教授 ', 教授 ') 
@ 调用 系统 存储 过 程 将 规则 prof_rule 绑 定 到 teacher 表 的 prof 列 上 。 


EXEC sp_bindrule 'prof_rule', ‘teacher. prof 
系统 给 出 提示 信息 “已 将 规则 绑 定 到 表 的 列 。” 
@@ 执行 如 下 插入 语句 : 


INSERT INTO teacher 
VALUES( 't05002', ' 张 源 ', "软件 工程 ', ' 工 程 师 ', ' 计 算 机 学 院 ') 


由 了 


合 条 件 的 记录 无 法 实现 操作 ,并 显示 错误 提示 信息 : 


F teacher 表 的 prof 列 绑 定 了 规则 prof_rule, 当 插入 和 更 新 记录 时 所 有 “职称 ”不符 
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消息 513, 级 别 18, 状态 0, 第 1 行 

列 的 插入 或 更 新 与 先前 的 CREATE RULE 语句 所 指定 的 规则 发 生 冲 突 。 该 语句 已 终止 。 冲 突 发 生 于 数 

据 库 'teaching', 表 'dbo. teacher', 列 'prof'。 

语句 已 终止 。 

(9) 利用 Transact-SQL 语句 为 teaching 数据 库 创建 默认 值 对 象 Email_default, 规 定 电 
子 邮箱 地 址 默认 为 “无 ”, 并 将 其 绑 定 到 student 表 的 Email 列 上 。 

@ 在 teaching 数据 库 中 创建 默认 值 对 象 Email_default。 


CREATE DEFAULT Email_ default RS ' 无 ' 

@ 调用 系统 存储 过 程 将 默认 值 对 象 Email _default 绑 定 到 student 表 的 Email 列 上 。 

EXEC sp_bindefault 'Email default', 'student. Email' 

系统 给 出 提示 信息 “已 将 默认 值 绑 定 到 列 。” 

@ 执行 如 下 插入 语句 : 

INSERT INTO student( studentno, sname, sex, birthdate, classno) 

VALUES( '18122221328', ' 张 源 ', ' 男 ', '1995 -04 一 05', '180501') 

由 于 student 表 的 Email 列 绑 定 了 默认 值 对 象 Email_default, 当 插入 或 更 新 记录 时 , 若 
没有 指定 Email 列 的 值 , 则 系统 采用 该 列 的 默认 值 。 

(10) 利用 Tansact-SQL 语句 删除 teaching 数据 库 中 的 规则 prof_rule 和 默认 值 Email_ 
default 。 

GD 调用 系统 存储 过 程 解 除 绑 定 到 teacher 表 的 prof 列 上 的 规则 prof_rule 和 student 
表 的 Email 列 的 默认 值 对 象 Email_default 。 


EXEC sp_unbindrule 'teacher. prof' 

EXEC sp_unbindefault 'student. Email’ 

系统 分 别 给 出 提示 信息 “已 解除 了 表 列 与 规则 之 间 的 绑 定 ”和 “已 解除 了 表 列 与 其 默认 
值 之 间 的 绑 定 。”。 

@ 删除 规则 prof_rule 和 默认 值 对 象 Email_default。 

DROP RULE prof_rule 

DROP DEFAULT Email default 

(11) 在 “D:\DATA\" 下 创建 一 个 Access 数据 库 文件 student. MDB, 将 teaching 数据 
库 中 的 student 表 导 出 到 student. MDB 中 ,并 更 改 表 名 为 学 生 基 本 信息 。 

@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”一 “数据 库 ”, 右 击 teaching 
数据 库 ,在 弹出 的 快捷 菜单 中 选择 “任务 一 导出 数据 ?命令 ,弹出 “SQL Server 导入 导出 向 
导 ?” 初 始 界面 。 

@ 选择 数据 源 类 型 。 单 击 “ 下 一 步 " 按 钮 ,打开 “选择 数据 源 ” 对 话 框 。 在 “数据 源 ” 下 拉 
列表 框 中 选择 默认 的 SQL Native Client, 在 “服务 器 名 称 ” 下 拉 列 表 框 中 选择 或 输入 本 地 默 
认 实 例 ,在 “身份 验证 ”选项 组 中 选择 “使 用 Windows 身份 验证 ” 单 选 按 钮 ,在 “数据 库 ” 下 拉 
列表 框 中 选择 或 输入 student 表 。 

@ 选择 目标 。 单 击 “ 下 一 步 ” 按 钮 ,打开 “选择 目标 "对话 框 ,在 “目标 ”下 拉 列 表 框 中 选 


择 Microsoft Access 选项 ,在 “文件 名 ”文本 框 中 输入 或 单 击 “ 浏 览 ” 按 钮 定位 文件 “D:\ 
DATA\student. MDB”。 单 击 “ 高 级 ”按钮 ,出 现 “ 数 据 链接 属性 ”对 话 框 ,在 “连接 ”选项 卡 中 
单 击 “ 测 试 连接 ”按钮 ,测试 能 否 与 该 数据 库 连 接 。 单 击 “ 确 定 ” 按 钮 ,返回 到 “SQL Server 导 
入 导出 向 导 ” 界 面 。 

@ 指定 复制 或 查询 操作 。 单 击 " 下 一 步 ” 按 钮 ,选择 “复制 一 个 或 多 个 表 或 视图 的 数据 ” 
单 选 按 钮 。 

@ 选择 源 表 和 源 视图 。 单 击 “ 下 一 步 ” 按 钮 ,打开 “选择 源 表 和 源 视图 ”对 话 框 ,在 表 和 
视图 列表 的 “ 源 ” 列 中 选择 student 表 , 在 “目标 ” 列 将 表 名 修改 为 “学 生 基 本 信息 ”。 单 击 “ 映 
射 ? 列 的 “编辑 ?按钮 可 实现 目标 表 结 构 的 修改 。 

@ 保存 并 执行 包 。 单 击 * 下 一 步 " 按 钮 ,进入 “保存 并 执行 包 ” 对 话 框 。 选 择 “ 立 即 执行 ” 
复 选 框 ,将 立即 运行 包 。 

@ 完成 。 单 击 “ 下 一 步 "按钮 ,进入 “完成 该 向 导 ” 对 话 框 。 单 击 “ 完 成 ”按钮 ,进入 “执行 
成 功 ” 对 话 框 。 单 击 “ 关 闭 ” 按 钮 ,导出 数据 执行 完毕 。 

查看 数据 。 打 开 student. MDB 数据 库 的 学 生 基 本 信息 表 , 其 中 内 容 与 teaching 数 
据 库 的 student 表 内 容 一 致 ,表明 导出 数据 成 功 。 

4. 实验 报告 总 结 

(1) 不 同类 型 数据 完整 性 的 特点 和 实现 方法 。 

(2) 各 种 约束 的 功能 及 对 表 数 据 修改 的 影响 。 

(3) 规则 和 默认 值 对 象 与 数据 列 的 绑 定 和 解除 绑 定 。 


实验 5 Transact-SQL 语句 基础 


1. 实验 目的 

(1) 掌握 利用 各 种 数据 类 型 声明 局 部 变量 的 方法 。 

(2) 掌握 为 局 部 变量 赋值 的 两 种 方法 。 

(3) 掌握 常用 系统 函数 .运算 符 和 表达 式 的 功能 及 应 用 。 

2. 实验 预习 与 准备 

主教 材 5. 1 一 5. 5 节 , 本 书 第 5 章 。 

(1) 常规 标识 符 的 命名 规则 。 

(2) 局 部 变量 的 声明 和 赋值 方法 。 

(3) 常用 运算 符 的 使 用 方法 及 其 优先 级 。 

(4) 常用 系统 函数 的 功能 和 调用 方法 。 

3. 实验 内 容 及 步 又 

(1) 变量 的 应 用 

在 为 变量 赋值 的 语句 中 ,SET 命令 一 次 只 能 为 一 个 变量 赋值 ,而 SELECT 命令 一 次 可 
以 为 多 个 变量 赋值 。 

注意 几 种 字符 数据 类 型 的 区 别 和 赋值 语句 中 表达 式 与 变量 类 型 不 同 的 情况 。 

DECLARE (@ sno CHAR(8), @name VARCHAR(10), @ sex NCHAR(2), @birthdate DATETIME, @ daily INT, 


@final NUMERIC(4, 1) 
SET @sno= '17122111208， 
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SET @name = ' 韩 吟 秋 ， 

SET @sex= ' 男 ' 

SELECT @birthdate = '1999 -12 — 18', @daily= 88.5, @final = 90 
PRINT @sno+ @name + @sex 

PRINT @birthdate 

PRINT @daily 

PRINT @final 


(2) 运算 符 的 应 用 
O@ 算术 运算 符 


BRINT getdate() + 100 
PRINT 123+ 23%10/7+ (17 -6)*2.5 


@ 比较 运算 符 


USE teaching 
G0 

-- 查询 生日 在 '1999 - 01 -01' 之 后 的 学 生 信息 

SELECT * FROM student WHERE birthdate>'1999— 01—01' 
-- 查询 不 是 在 计算 机 学 院 工作 的 教师 信息 

SELECT x* FROM teacher WHERE department <>' 计 算 机 学 院 ' 


@ 逻辑 运算 符 

USE teaching 

G0 

=- 查询 18 级 期 末 成 绩 在 80 一 90 的 学 生成 绩 信息 
SELECT * FROM score WHERE studentno LIKE '18% 'AND 
final BETWEEN 80 AND 90 

-- 查 询 职称 为 教授 ' 或 ' 副 教授 ' 的 教师 信息 

SELECT x* FROM teacher WHERE prof IN (' 教 授 ', ' 副 教授 ') 


@ 字符 串 连接 运算 符 


“十 ” 既 可 作为 算术 运算 符 ,又 可 作为 字符 串 连 接 运 算 符 。 当 两 个 运算 对 象 均 为 数值 类 
型 或 字符 类 型 时 ,分 别 实现 的 是 算术 的 加 法 运算 和 字符 串 连 接 。 当 两 个 运算 对 象 不 同时 , 系 


统 将 自动 实现 类 型 的 隐 式 转换 , 若 转 换 无 法 实现 , 则 系统 给 出 错误 提示 信息 。 


DECLARE @A CHAR(5), @B VARCHAR(5), @C INT, @D DECIMAL(5, 2) 
SELECT @A = '123', @B= '456.5', @C = 123, @D= 456.5 

PRINT @A+ @B 

PRINT @A+ @D 

PRINT @C + @D 

SELECT @A= ' 数 据 库 ', @B= ' 程 序 开发 ' 

PRINT @A+ @B 

PRINT @A+ @D 


@ 位 运算 符 
DECLARE @A INT, @B INT 


SELECT @A= 5,@B= 12 
SELECT @AE@B, @A| @B, @A“@B, ~@A 


(3) 系统 函数 的 应 用 

@ 数学 函数 

SELECT CEILING(16.3), CEILING( ~ 16.8)，CEILING(0.0) 
SELECT FLOOR(16.3), FLOOR( - 16.8), FLOOR(0.0) 


SELECT ROUND(123. 456, 2), ROUND(123.456, — 1), ROUND(123.456, — 2), ROUND(123.456, — 4) 
SELECT ROUND(175. 86,0),ROUND(175. 86,0,1) 


ROUND 的 数 的 语法 格式 为 : 


ROUND( numeric expression, length[ ,function]) 


其 中 ,各 参数 的 含义 如 下 : 
。 length: numeric_expression 的 舍 人 精度 。 
名 如 果 length 为 正 数 , 则 将 numeric_expression 伟人 到 length 指定 的 小 数位 数 。 如 
果 length 为 负数 , 则 将 numeric_expression 小 数 点 左边 部 分 舍 人 到 length 指定 的 
长 度 。 
如 如 果 length 为 负数 ,并 且 大 于 小 数 点 前 的 数字 个 数 , 则 ROUND 函数 将 返回 0。 
function: 要 执行 的 操作 类 型 。function 必须 为 tinyint、 smallint 或 int。 如 果 省 略 
function 或 其 值 为 0( 默 认 值 ), 则 将 舍 和 人 numeric_expression。 如 果 指 定 了 0 以 外 的 值 , 则 
将 截断 numeric_expression。 
@ 时 间 日 期 函数 
DECLARE @birthdate DATETIME 
SET @birthdate = '1999 -12—18' 
SELECT (@birthdate AS ' 生 日 ', DATEDIFF(Year, @birthdate, GETDATE( )) RS ' 年 龄 ' 


SELECT GETDATE( ) AS ' 当 前 日 期 '，YEAR(GETDATE( ) )AS ' 年 份 '，DATEPART(Month, GETDATE( ) )AS ' 月 份 '， 
DATENAME( Day, GETDATE( ) )AS ' 日 期 ' 


@ 转换 函数 


DECLARE @count INT, @date DATETIME 

SELECT @count = 255, @date = GETDATE!( ) 

PRINT ' 变 量 count 的 值 为 : '+ CAST(@count RS VARCHAR(5)) 
PRINT CAST( '2016 — 12 - 25' AS SMALLDATETIME) + 100 

PRINT CONVERT( VARCHAR(10), @date, 102) 


@ 字符 串 函 数 


DECLARE @str RS NCHAR(25) 

SET @str = 'SQL SERVER 2016 数据 库 应 用 与 开发 ' 

SELECT LEN( @str), CHARINDEX( ' 数 据 库 '，@ str)，SUBSTRING( @str, 5,6)，REPLACE(@str, ' 开 发 ',' 设 
计 '), LOWER(@str), ASCII(@str) 


4. 实验 报告 总 结 
(1) 局 部 变量 两 种 赋值 方法 的 区 别 。 


(2) 数据 类 型 的 隐 式 转换 和 显示 转换 。 
(3) 运算 符 的 应 用 以 及 系统 函数 的 调用 方法 。 章 


侨 验 振 时 与 实验 内 容 


SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 志 指 时 


实验 6 利用 控制 流 语 句 编程 


1. 实验 目的 

(1) 掌握 Transact-SQL 控制 流 语 句 的 基本 功能 和 分 类 。 

(2) 掌握 利用 控制 流 语 句 实现 基本 的 分 支 选 择 和 循环 处 理 功能 。 

(3) 了 解 其 他 控制 流 语句 的 功能 和 应 用 。 

2. 实验 预习 与 准备 

主教 材 第 5 章 5. 6 节 , 本 书 第 5 章 。 

(1) 利用 BEGIN…END 语句 定义 语句 块 。 

(2) 利用 IF…ELSE 语句 和 CASE 语句 实现 分 支 选择 。 

(3) 利用 WHILE…CONTINUE…BREAK 语句 实现 循环 处 理 。 

3. 实验 内 容 及 步 又 

(1) 编写 程序 根据 姓名 查询 teaching 数据 库 中 学 生 的 基本 信息 和 选课 信息 ,学 生 姓名 
通过 变量 输入 。 对 不 存在 的 学 生 姓名 输入 值 ,打印 提示 信息 。 


USE teaching 
G0 
DECLARE (@sname NCHAR(8) 
SET @ sname = ' 许 海 冰 ' 
IF EXISTS(SELECT * FROM student WHERE sname = @sname) 
SELECT student. * ,courseno, daily, final 
FROM student, score 
WHERE student. studentno = score. studentno AND sname = @ sname 
ELSE 
PRINT ' 提 示 : 不 存在 姓名 为 ' + RTRIM(@sname) + “的 学 生 资料 !… 


(2) 编写 程序 查询 所 有 学 生 选 修 课程 的 期 末 成 绩 和 对 应 等 级 ,如 学 生 未 选修 任何 课程 
则 输出 提示 信息 。 

多 分 支 选择 结构 可 通过 CASE 语句 实现 。 在 实现 多 表 连 接 时 ,需要 查询 未 选修 任何 课 
程 的 学 生 信 息 , 即 需要 查询 在 student 表 中 存在 而 在 score 表 中 不 存在 的 学 生 记录 。 外 连接 
LEFT JOIN 可 实现 此 项 功能 。 


USE teaching 
GO 
SELECT student. studentno, sname, cname, final, 
CASE 
WHEN final > = 90 THEN ' 优 ' 
WHEN final >= 80 THEN ' 良 ' 
WHEN final >= 70 THEN ' 中 ， 
WHEN final > = 60 THEN ' 及 格 ' 
WHEN final < 60 THEN ' 不 及 格 ' 
WHEN final IS NULL THEN ' 未 选修 任何 课程 ' 
END AS level 
FROM student LEFT JOIN score ON (student. studentno = score. studentno) LEFT JOIN course ON 


(course. courseno = score. courseno) 


(3) 编写 程序 判断 字符 变量 @ch 中 存放 的 是 字母 字符 ,数字 字符 还 是 其 他 字符 ,并 输出 
相关 信息 。 
通过 IF…ELSE 语句 实现 的 代码 如 下 : 


DECLARE @ch CHAR 
SELECT @ch= 'a' 
IF UPPER( @ch)> = 'A' and UPPER( @ch)<= 'Z' 
PRINT @ch + ' 是 字母 字符 ' 
ELSE 
IF @ch>= '0'and @ch<= '9' 
PRINT @ch+ ' 是 数字 字符 ' 
ELSE 
PRINT @ch+ ' 是 其 他 字符 ' 


通过 CASE 语句 实现 的 代码 如 下 : 


DECLARE @ch CHAR 

SELECT @ch= 'a' 

PRINT 

CRSE 

WHEN UPPER(@ch)> = 'A' AND UPPER(@ch)<= 'Z' THEN @ch+ ' 是 字母 字符 ' 
WHEN @ch>= '0'RND @ch<= '9'THEN @ch+ ' 是 数字 字符 ' 
ELSE @ch+ ' 是 其 他 字符 ' 

END 


(4) 编写 程序 判断 某 个 年 份 是 否 为 头 年 ,年 份 由 变量 输入 。 


DECLARE @ Year int 
SET @year = YEAR( GETDATE( )) 
IF @year% 4=0 
BEGIN 
IF @year %100=0 
BEGIN 
IF @year% 400=0 
PRINT CAST( @year AS CHAR(4)) + “年 是 半年 ' 
ELSE 
PRINT CAST( @year AS CHAR(4)) + “年 不 是 头 年 ' 
END 
ELSE 
PRINT CAST( @year RS CHAR(4)) + ' 年 是 半年 ' 
END 
ELSE 
PRINT CAST( @ year AS CHAR(4) ) + ' 年 不 是 半年 ' 


(5) 编写 程序 输出 在 1 一 3000 之 间 能 被 17 整除 的 最 大 数值 。 

该 程序 求解 满足 条 件 的 最 大 数值 ,可 使 循环 控制 变量 从 最 大 值 开 始 逐 步 减 少 ,第 一 个 满 
足 被 17 整除 的 数值 即 为 所 求解 的 结果 ,可 通过 BREAK 语句 跳出 循环 。 如 果 按 常规 思路 使 
循环 控制 变量 从 小 到 大 逐步 增加 , 则 循环 次 数 将 大 大 增加 ,程序 执行 效率 下 降 。 

程序 代码 如 下 : 


DECLARE @s INT, @i INT 
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SELECT @s= 0,@i= 3000 
WHILE @i>=1 
BEGIN 
IF @i%17=0 
BEGIN 
PRINT '1 一 3000 之 间 能 被 整除 的 最 大 数值 为 : '+ CAST( @i RS CHAR(4)) 
BREAK 
END 
SET @i=@i-1 
END 


(6) 编写 程序 采用 加 转 相 除法 求解 两 个 正 整 数 的 最 大 公约 数 。 


DECLARE @m INT, @n INT 
SELECT @m= 21, @n= 12 
DECLARE Qt INT, @r INT 
PRINT CAST( @m AS VARCHAR(5)) + ' 和 '+ CAST(@n AS VARCHAR(5)) + ' 的 最 大 公约 数 为 : ' 
IF @nm<@n SELECT @t= @nm, @n= @n, @n= @t 
SET @r = @n% @n 
WHILE @r <>0 
SELECT @n= @n, @n= @r, @r= @ns% @n 
PRINT CAST( @n AS VARCHAR(5)) 


(7) 编写 程序 将 十 进 制 数值 转换 为 二 进 制 字 符 串 后 输出 。 


DECLRRE @ch NCHAR(10), @n INT, @a INT 
SET @n = 20 
SET @ch=" 
PRINT CRST(@n AS VARCHAR(5)) + ' 的 二 进 制 为 : ， 
WHILE @n <> 0 
BEGIN 
SET @a = @n%2 
SET @n = @n/2 
SET @ch = CHAR(48 + @a) + @ch 


END 
PRINT @ch 
(8) 编写 程序 求解 如 下 分 数 序 列 的 前 n 项 之 和 并 打印 输出 结果 ,n 由 变量 输入 。 
本 
STtstaststetit 


分 析 数 列 的 规律 ,下 一 项 的 分 子 为 前 一 项 的 分 子 和 分 母 之 和 ,下 一 项 的 分 母 则 为 前 一 项 
的 分 子 ,通过 循环 即 可 实现 累加 。 注 意 , 如 声明 分 子 和 分 母 为 整 型 ,在 进行 除法 运算 时 计算 
的 结果 必 为 整 型 ,影响 最 终 计 算 精 度 , 因 此 需 将 其 声明 为 浮 点 数 类 型 。 


DECLARE @n INT, @i INT 
DECLARE @s NUMERIC(20,7), @x NUMERIC(20,7), @y NUMERIC(20,7), @t NUMERIC(20,7) 
SELECT @n= 20,@i=1,@s=0,@x=2,@y=1 
WHILE @i<= @n 
BEGIN 
SET @s= @s+ @x/@y 
SELECT @t = @x, @x= @x+ @y, @y= @t 


SET @i=@i+1l 
END 
PRINT ' 数 列 前 ' + CMST(@n AS VARCHAR(6)) + ' 项 之 和 为 : '+ CAST(@s AS VARCHAR(25)) 
4. 实验 报告 总 结 
(1) IF… ELSE 语句 和 CASE 语句 实现 分 支 选 择 的 区 别 以 及 CASE 语句 的 两 种 
形式 。 
(2) WHILE 语句 中 BREAK 和 CONTINUE 的 功能 和 应 用 。 
(3) 嵌 套 IF…ELSE 语句 的 特点 和 使 用 注意 事项 。 


实验 7 数据 检索 


1. 实验 目的 

(1) 掌握 SELECT 各 个 子 句 的 功能 和 检索 数据 的 方法 。 

(2) 掌握 WHERE 子 句 中 LIKE、IN、BETWEEN .IS 等 逻辑 运算 符 的 使 用 。 
(3) 掌握 WITH ROLLUP 语句 和 聚合 函数 的 使 用 。 

2. 实验 预习 与 准备 

主教 材 第 6 章 ,本 书 第 6 章 。 

(1) 利用 SELECT…FROM 子 句 实现 投影 查询 和 设置 结果 集 格式 。 
(2) 利用 WHERE 子 句 实现 数据 过 滤 。 

(3) 利用 GROUP BY 子 句 和 HAVING 子 句 实现 分 组 查询 。 

(4) 利用 ORDER BY 子 句 实现 结果 集 排序 。 

(5) WITH ROLLUP 语句 和 聚合 函数 的 使 用 。 

3. 实验 内 容 及 步 又 

(1) 查询 所 有 课程 的 课程 编号 .课程 名 和 学 分 。 

USE teaching 

GO 


SELECT courseno, cname, period/16.0 
FROM course 


(2) 查询 180501 班 所 有 学 生 的 基本 信息 。 


USE teaching 
GO 

SELECT * 

FROM student 

WHERE classno = '180501” 


(3) 查询 student 表 中 所 有 年 龄 大 于 20 岁 的 男生 的 姓名 和 年 龄 。 


USE teaching 

GO 

SELECT sname, DATEDIFF(Year, birthdate, GETDATE( ) ) AS age 
FROM student 

WHERE DATEDIFF (Year, birthdate, GETDATE( ) )> 20 AND sex= ' 男 ' 
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(4) 查询 计算 机 学 院 教师 的 专业 名 称 。 


USE teaching 

GO 

SELECT DISTINCT major 

FROM teacher 

WHERE department = ' 计 算 机 学 院 ' 


(5) 查询 选修 课程 且 期 末 成 绩 不 为 空 的 学 生 人 数 。 


USE teaching 

GO 

SELECT COUNT(DISTINCT studentno) RS ' 选 修 课程 学 生 人 数 ' 
FROM score 

WHERE final IS NOT NULL 


(6) 查询 所 有 E-mail 使 用 126 邮箱 的 学 生 的 学 号 、 姓 名 和 电子 邮箱 地 址 。 


USE teaching 

G0 

SELECT studentno, sname, Email 
FROM student 

WHERE Email LIKE '% 126.com%' 


由 于 E-mail 列 定义 为 Unicode 固定 长 度 字符 数据 类 型 nchar(20) ,如果 数 据 表 中 该 字 
段 的 字符 串 长 度 小 于 20, 则 系统 自动 在 其 后 添加 空格 ,因此 本 例 在 '126. com' 后 仍 需 使 用 通 
配 符 。 

(7) 查询 每 名 学 生 的 学 号 .选修 课程 数目 、 总 成 绩 ,并 将 查询 结果 存放 到 生成 的 “学 生 选 
课 统 计 表 ” 中 。 

Q@ 利用 INTO 子 句 生成 新 表 , 将 SELECT 查询 结果 存放 其 中 。 

USE teaching 

GO 

SELECT studentno, COUNT( * ) RS ' 选 课 数目 , SUM(final) AS ' 总 成 绩 ' 

INTO 学 生 选 课 统计 表 

FROM score 

GROUP BY studentno 


@ 查询 新 表 中 的 数据 。 

SELECT * FROM 学 生 选 课 统计 表 

(8) 查询 score 表 中 选修 c05109 或 c05103 课程 .并且 课程 期 末 成 绩 在 90 一 100 分 的 学 
生 姓 名 和 期 末 成 绩 。 


USE teaching 

GO 

SELECT sname, final 
FROM score 


WHERE final BETWEEN 90 AND 100 RND courseno IN ('c05109', 'c05103') 


(9) 查询 student 表 中 所 有 学 生 的 基本 信息 ,查询 结果 按 班 级 号 classno 升序 排列 ,同一 
班级 中 的 学 生 按 人 学 成 绩 point 降序 排列 。 


USE teaching 

GO 

SELECT * 

FROM student 

ORDER BY classno ASC, point DESC 


(10) 查询 选修 c05109 课程 ,并 且 期 末 成 绩 在 前 5 名 的 学 生 学 号 .课程 号 和 期 末 成 绩 。 


USE teaching 

GO 

SELECT TOP 5 studentno,courseno,final 
FROM score 

WHERE courseno = 'c05109 

ORDER BY final DESC 


(11) 查询 各 班 学 生 的 人 数 。 


USE teaching 

GO 

SELECT classno, COUNT( * )AS count 
FROM student 

GROUP BY classno 

ORDER BY classno 


(12) 查询 各 班期 末 成 绩 的 最 高 分 和 最 低 分 。 


USE teaching 
G0 

SELECT courseno, MAX(final) AS max, MIN(final) AS min 
FROM score 

WHERE final IS NOT NULL 

GROUP BY courseno 


(13) 查询 教授 两 门 及 两 门 以 上 课程 的 教师 编号 .课程 编号 和 任课 班级 。 


USE teaching 

GO 

SELECT teacherno, COUNT( courseno) AS count 
FROM teach class 

GROUP BY teacherno 

HAVING COUNT(courseno)>= 2 


(14) 查询 课程 编号 以 c05 开头 ,被 3 名 及 3 名 以 上 学 生 选 修 , 且 期 末 成 绩 的 平均 分 高 
于 75 分 的 课程 号 .选修 人 数 和 期 末 成 绩 平均 分 ,并 按 平均 分 降序 排序 。 


USE teaching 
GO 
SELECT courseno, COUNT( studentno) AS count, AVG(final) AS average 
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FROM score 

WHERE courseno LIKE 'c05 % ' AND final IS NOT NULL 
GROUP BY courseno 

HAVING COUNT( studentno)> = 3 AND AVG(final)>= 75 
ORDER BY AVG(final) DESC 


(15) 查询 所 有 17 级 学 生 每 人 的 期 末 成 绩 平均 分 ,以 及 所 有 人 的 期 末 成 绩 平均 分 的 汇 
USE teaching 

GO 

SELECT studentno, AVG(final) 

FROM score 

WHERE studentno LIKE '17%"' 

Group by studentno 

With rollup 

ORDER BY studentno 


4. 实验 报告 总 结 

(1) 逻辑 运算 符 在 WHERE 子 句 中 的 使 用 方法 。 

(2) 利用 带 有 通配符 的 LIKE 实现 模糊 查询 及 利用 IS NULL 实现 空 值 查询 。 

(3) GROUP BY 子 句 中 分 组 依据 表达 式 与 SELECT 子 句 中 选择 列表 的 对 应 关系 。 


实验 8 Transact-SQL 语句 的 高 级 应 用 


1. 实验 目的 

(1) 掌握 多 表 连 接 查 询 、 子 查询 ,游标 、 大 对 象 类 型 数据 的 基本 概念 。 
(2) 掌握 多 表 连 接 的 各 种 方法 ,包括 内 连接 、 外 连接 、 交 又 连 接 等 。 
(3) 掌握 子 查询 的 方法 ,包括 相关 子 查询 和 不 相关 子 查询 。 

(4) 掌握 游标 处 理 结果 集 的 基本 过 程 。 

2. 实验 预习 与 准备 

主教 材 第 7 章 ,本 书 第 7 章 。 

(1) 利用 多 表 连 接 方式 查询 数据 。 

(2) 利用 子 查询 方式 查询 数据 。 

(3) 利用 游标 处 理 结果 集 的 基本 过 程 。 

3. 实验 内 容 及 步 又 

(1) 查询 所 有 班级 的 期 末 成 绩 平均 分 ,并 按照 平均 分 降序 排序 。 


USE teaching 
GO 

SELECT classno, AVG(final) 

FROM score INNER JOIN student 

ON (score. studentno = student. studentno) 
WHERE final IS NOT NULL 

GROUP BY classno 

ORDER BY AVG(final) DESC 


(2) 查询 教师 基本 信息 和 教授 课程 信息 ,其 中 包括 未 分 配 课程 的 教师 信息 。 


USE teaching 

G0 

SELECT teacher. * ,courseno, classno 
FROM teacher LEFT JOIN teach class 


ON (teacher. teacherno = teach class. teacherno) 


(3) 查询 180501 班级 中 选修 了 “ 韩 晋升 ”老师 讲授 的 课程 的 学 生 学 号 、 姓 名 、 课 程 名 和 
期 末 成 绩 。 


USE teaching 

GO 

SELECT student. studentno, sname, cname, final 

FROM score JOIN student ON (score. studentno = student. studentno) 
JOIN course ON ( score. courseno = course. courseno) 
JOIN teach class ON (score. courseno = teach class. courseno) 
JOIN teacher ON (teach class. teacherno = teacher. teacherno) 

WHERE tname = ' 韩 晋升 ' AND student. classno = '180501' 


(4) 查询 每 门 课程 的 课程 号 课程 名 和 选修 该 课程 的 学 生 人 数 ,并 按 所 选 人 数 升序 
排序 。 


USE teaching 

GO 

SELECT course. courseno, cname, COUNT( * ) 

FROM score JOIN student ON (score. studentno = student. studentno) 
JOIN course ON (score. courseno = course. courseno) 

GROUP BY course. courseno, cname 

ORDER BY COUNT( * ) 


(5) 查询 两 门 及 两 门 以 上 课程 的 期 末 成 绩 超过 80 分 的 学 生 姓名 及 其 平均 成 绩 。 


USE teaching 
GO 

SELECT student. studentno, sname, AVG(final) AS avgerage 
FROM student INNER JOIN score 

ON (student. studentno = score. studentno) 

WHERE final IS NOT NULL and final >= 80 

GROUP BY student. studentno, sname 

HAVING COUNT( * )>= 2 


(6) 查询 入 学 考试 成 绩 最 高 的 学 生 学 号 、 姓 名 和 入 学 成 绩 。 


USE teaching 

GO 

SELECT studentno, sname, point 

FROM student 第 
WHERE point = (SELECT MAX(point) 18 
FROM student) 章 
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(7) 查询 所 有 教授 c05127 号 课程 的 教师 信息 。 


USE teaching 

GO 

SELECT * 

FROM teacher 

WHERE teacherno IN (SELECT teacherno 
FROM teach class 

WHERE courseno = 'c05127') 


(8) 查询 同时 教授 c05127 号 和 c05109 号 课程 的 教师 信息 。 


USE teaching 

GO 

SELECT * 

FROM teacher 

WHERE teacherno IN 

(SELECT a. teacherno 

FROM teach class a INNER JOIN teach class b 

ON (a. teacherno = b. teacherno) 

WHERE a. courseno = 'c05127' and b. courseno = 'c05109') 


(9) 查询 至 少 选修 了 姓名 为 “ 韩 吟 秋 ” 的 学 生 所 选修 课程 中 一 门 课 的 学 生 学 号 和 姓名 。 


USE teaching 

GO 

SELECT DISTINCT student. studentno, sname 

FROM student JOIN score ON (student. studentno = score. studentno) 

WHERE sname <>' 韩 吟 秋 ' AND courseno IN 

(SELECT courseno 
FROM score JOIN student ON( score. studentno = student. studentno) 
WHERE sname = ' 韩 吟 秋 ') 


(10) 查询 没有 被 任何 学 生 选 修 的 课程 编号 .课程 名 称 和 学 分 。 


USE teaching 

GO 

SELECT courseno, cname, period/16.0 

FROM course 

WHERE NOT EXISTS(SELECT * 

FROM score 

where score. courseno = course. courseno) 


(11) 查询 “C 语言 课程 期 末 成 绩 比 *“ 电 子 技术 ”课程 期 末 成 绩 高 的 所 有 学 生 的 学 号 和 
姓名 。 


USE teaching 

GO 

SELECT student. studentno, sname 

FROM score scl JOIN student ON (scl. studentno = student. studentno) 
JOIN course cl ON (scl. courseno = cl. courseno) 

WHERE c1. cname = 'C 语言 ' and EXISTS 

(SELECT * FROM score sc2 JOIN course c2 


ON (sc2. courseno = c2. courseno) 
WHERE c2. cname = ' 电 子 技术 'and sc1. studentno = sc2. studentno and sc1. final > sc2. final) 


(12) 查询 所 有 班级 期 末 平 均 成 绩 的 最 高 分 ,并 将 其 赋值 给 变量 ,通过 PRINT 语句 
输出 。 


USE teaching 
GO 
DECLARE @max NUMERIC(6, 2) 
SELECT (@max = MAX( 平 均 分 ) 
FROM (SELECT classno AS 班级 号 , AVG(final) AS 平均 分 
FROM score JOIN student 
ON (score. studentno = student. studentno) 
JOIN course ON (course. courseno = score. courseno) 
WHERE final IS NOT NULL 
GROUP BY classno)t 
PRINT ' 所 有 班级 期 末 平 均 成 绩 的 最 高 分 为 : '+ CAST( @max RS VARCHAR(6)) 


(13) 使 用 游标 输出 学 生 姓名 .选修 课程 名 称 和 期 末 考试 成 绩 。 


USE teaching 
GO 
DECLARE @ sname nchar(8), @cnanme nchar(10), @final numeric(6,2) 
DECLARE sc_cursor CURSOR FOR 
SELECT sname, cname, final 
FROM score JOIN student ON (score. studentno = student. studentno) 
JOIN course ON (score. courseno = course. courseno) 
OPEN sc_cursor 
FETCH NEXT FROM sc_cursor INTO (@ sname, @cname, @final 
PRINT ' 学 生 姓 名 课程 名 称 ”期 末 成 绩 ' 


WHILE @@FETCH STATUS = 0 
BEGIN 
PRINT @ sname + @cname + CAST( @final AS nchar(6)) 
FETCH NEXT FROM sc_cursor INTO @ sname, @cname, @final 
END 
CLOSE sc_cursor 
DEALLOCATE sc_cursor 


(14) 使 用 游标 统计 每 个 学 院 教师 所 开设 课程 的 选修 率 。 


USE teaching 
GO 
DECLARE @dept nchar(12), @rate numeric(4,1) 
DECLARE rate_cursor CURSOR FOR 
SELECT a. department, CAST( scnum * 100. 0/cnum RS numeric(4,1)) ASr 
FROM (SELECT department, COUNT(course. courseno) RS cnum 
FROM teach class JOIN course 
ON (teach class. courseno = course. courseno) 


JOIN teacher ON (teach class. teacherno = teacher. teacherno) 第 
GROUP BY department)a, 18 
(SELECT department, COUNT(DISTINCT course. courseno) AS scnum 章 
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FROM teach class JOIN course 
ON (teach class. courseno = course. courseno) 
JOIN teacher ON (teach class. teacherno = teacher. teacherno) 
JOIN score ON (score. courseno = course. courseno) 
GROUP BY department)b 
WHERE a. department = b. department 
OPEN rate_cursor 
FETCH NEXT FROM rate_cursor INTO @dept, @rate 
WHILE @(@FETCH STRTUS = 0 
BEGIN 
PRINT RTRIM( @dept) + ' 课 程 的 选修 率 为 '+ CAST(@rate AS varchar(5))+'%"' 
FETCH NEXT FROM rate_cursor INTO @dept, @rate 
END 
CLOSE rate_cursor 
DEALLOCATE rate_ cursor 


(15) 使 用 游标 计算 学 生 期 末 成 绩 的 等 级 。 
@ 在 score 表 中 新 增 等 级 字段 level。 


USE teaching 
ALTER TABLE score ADD level nchar(3) NULL 


@ 使 用 游标 计算 学 生 期 末 成 绩 的 等 级 ,并 更 新 level 列 。 


DECLARE @final numeric(6,2),@1level nchar(3) 
DECLARE score_cursor CURSOR FOR 
SELECT final FROM score WHERE final IS NOT NULL 
OPEN score_ cursor 
FETCH NEXT FROM score_cursor INTO @final 
WHILE @@FETCH STRTUS = 0 
BEGIN 
SET @level = CASE 
WHEN @final > = 90 AND @final<= 100 THEN ' 优 秀 ' 
WHEN @final > = 80 Then ' 良 好 ' 
WHEN @final >= 70 Then ' 中 等 ' 
WHEN @final >= 60 Then ' 及 格 ' 
ELSE ' 不 及 格 ' 
END 
UPDATE score SET level = @level WHERE CURRENT OF score_cursor 
FETCH NEXT FROM score_cursor INTO @final 
END 
CLOSE score_cursor 
DEALLOCATE score_cursor 


@ 查看 使 用 游标 修改 数据 表 后 的 结果 。 


SELECT * FROM score 


4. 实验 报告 总 结 
(1) 内 连接 与 外 连接 的 功能 及 区 别 。 
(2) 相关 子 查询 与 不 相关 子 查询 的 功能 及 区 别 。 


(3) 利用 游标 处 理 结果 集 的 基本 过 程 和 方法 。 
实验 9 索引 和 视图 


1. 实验 目的 

(1) 掌握 索引 和 视图 的 基本 概念 及 功能 。 

(2) 掌握 利用 SQL Server Management Studio 和 Transact-SQL 语句 创建 ,维护 索引 的 
方法 。 

(3) 掌握 利用 SQL Server Management Studio 和 Transact-SQL 语句 创建 ,修改 视图 的 
方法 。 

(4) 掌握 通过 视图 插入 修改、 删除 基本 表 中 数据 的 方法 及 注意 事项 。 

2. 实验 预习 与 准备 

主教 材 第 8 章 ,本 书 第 8 章 。 

(1) 利用 SQL Server Management Studio 和 Transact-SQL 语句 创建 、 维 护 索 引 。 

(2) 利用 SQL Server Management Studio 和 Transact-SQL 创建 、 修 改 视 图 。 

(3) 通过 视图 查看 和 修改 基本 表 中 的 数据 。 

3. 实验 内 容 及 步 又 

(1) 利用 SQL Server Management Studio 为 student 表 的 classno 字段 创建 非 聚 集 非 
唯一 索引 UC_classno。 

@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”一 “数据 库 ” 一 teaching 数 
据 库 一 “ 表 ”。 

@ 选择 student 表 并 展开 , 右 击 “索引 ?选项 ,在 弹出 的 快捷 菜单 中 选择 "新建 索 引 ” 
命令 。 
@ 在 弹出 的 “新 建 索引 ?对 话 框 中 选择 “常规 ?选项 卡 , 输 入 索引 名 称 为 UC_classno ,在 
索引 类 型 组 合 框 中 选择 “ 非 聚集 "唯一 ” 复 选 框 为 未 选中 状态 。 

@ 设置 完成 后 , 单 击 索 引 键 列 的 “添加 ?按钮 ,出 现 从 dbo. student 中 选择 列 对 话 框 ,在 
“ 表 列 ”列表 中 选中 classno 列 。 

@@ 索引 键 列 设置 完毕 , 单 击 “确定 ”按钮 ,返回 到 * 新 建 索引 ?对 话 框 , 在 “索引 键 列 ”中 的 
“排序 顺序 ”组 合 框 中 选择 “升序 ”为 索引 键 的 排序 顺序 。 

@ 在 “新 建 索 引 ” 对 话 框 中 切换 至 “选项 ”选项 卡 ,选中 “设置 填充 因子 ”和 “填充 索引 ” 复 
选 框 ,并 设置 填充 因子 为 70% ,其 余 选 项 均 采用 默认 设置 。 

@ 在 “新 建 索引 ”对 话 框 的 “包含 性 列 ” 和 “存储 ”选项 卡 中 均 采 用 默认 设置 。 

@ 完成 设置 后 ,在 “新 建 索引 ”对话 框 中 单 击 “确定 ”按钮 , 即 完成 了 创建 非 聚集 索引 的 
操作 。 

(2) 利用 Transact-SQL 语句 在 teaching 数据 库 中 的 teacher 表 的 tname 列 上 创建 非 聚 
集 唯一 索引 UQ_tname。 若 该 索引 已 存在 , 则 删除 后 重建 。 

Qa 在 查询 编辑 器 中 输入 如 下 创建 索引 的 代码 并 执行 : 

USE teaching 


GO 
IF EXISTS(SELECT name FROM sysindexes WHERE name = 'UQ tname') 
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DROP INDEX teacher.UQ tname 
GO 
CREATE UNIQUE INDEX UQ_tname ON teacher(tname) 


@) 执行 如 下 插入 语句 : 

INSERT INTO teacher(teacherno, tname, major, prof, department) 

VALUES( 't05002', ' 刘 元 朝 ', "软件 工程 ', ' 副 教授 ', ' 计 算 机 学 院 ') 

唯一 性 约束 确保 索引 列 不 包含 重复 的 值 。 由 于 IGNORE_DUP_KEY 默认 设置 为 
OFF, 则 插入 操作 出 现 重复 键 值 时 插入 失败 ,并 显示 如 下 错误 提示 信息 : 

消息 2601, 级 别 14, 状态 1, 第 1 行 

不 能 在 具有 唯一 索引 'UQ_tname' 的 对 象 'dbo. teacher' 中 插入 重复 键 的 行 。 

语句 已 终止 。 

(3) 利用 SQL Server Management Studio 查看 索引 被 查询 优化 器 使 用 的 情况 。 

OO 在 “查询 编辑 器 ”中 输入 如 下 代码 : 

SELECT * FROM student WHERE classno = '180502"' 

SELECT * FROM teacher WHERE tname = ' 刘 元 朝 ' 

@ 单 击 工具 栏 上 的 “显示 估计 的 执行 计划 ?按钮 , 即 可 查看 创建 的 索引 被 查询 优化 器 使 
用 的 情况 。 

(4) 利用 Transact-SQL 语句 修改 UQ_tname 的 索引 属性 , 当 执行 多 行 插入 操作 时 出 现 
重复 键 值 , 则 忽略 该 记录 , 且 设置 填充 因子 为 80% 。 

a 在 “查询 编辑 器 "中 输入 如 下 修改 索引 的 代码 并 执行 : 

USE teaching 

G0 


ALTER INDEX UQ tname ON teacher REBUILD 
WITH (PAD_INDEX = ON, FILLFACTOR = 80, IGNORE DUP_KEY = ON) 


@ 执行 如 下 插入 语句 : 

INSERT INTO teacher(teacherno, tname, major, prof, department) 

VALUES( 't05002，' 刘 元 朝 ，' 软 件 工程 ' 副 教授 ', ' 计 算 机 学 院 ') 

由 于 IGNORE_DUP_KEY 默认 设置 为 ON, 则 插入 操作 出 现 重 复 键 值 时 ,系统 给 出 一 
条 警告 信息 “已 忽略 重复 的 键 ”。 

(5) 利用 SQL Server Management Studio, 在 teaching 数据 库 中 创建 视图 v_course_ 
avg, 查 询 每 门 课程 的 课程 号 ,课程 名 及 选修 该 课程 的 学 生 的 期 末 成 绩 平均 分 ,并 且 按 平均 分 
降序 排序 。 

@ 启动 SQL Server Management Studio, 在“ 对象 资源 管理 器 ”中 展开 “数据 库 ” 子 
目录 。 

@ 选中 并 展开 数据 库 teaching, 右 击 * 视 图 ?选项 ,在 弹出 的 快捷 菜单 中 选择 “新 建 视 
图 ”命令 。 

@ 在 弹出 的 “添加 表 ” 对 话 框 中 ,使 用 Ctrl 键 或 Shift 键 同时 选择 course 和 score 两 个 
表 。 单 击 “ 添 加 ”按钮 , 即 可 将 其 添加 到 视图 的 查询 中 。 


@ 单 击 对 话 框 中 的 “关闭 ”按钮 ,返回 到 SQL Server Management Studio 的 视图 设 
计 界 面 。 

@ 为 视图 选择 包含 的 数据 列 。 在 关系 图 窗 格 中 ,设置 course 数据 表 的 courseno 和 
cname 数据 列 左边 的 复 选 框 为 选中 状态 , 即 可 将 这 两 个 数据 列 添加 到 查询 结果 集 内 。 

@ 指定 查询 条 件 。 在 网 格 窗 格 中 的 “ 表 ? 组 合 框 和 * 列 ?组 合 框 中 分 别 选择 score、score. 
final。 由 于 所 选 数据 列 只 作为 搜索 子 句 ,而 不 需要 在 结果 集 内 显示 ,因此 将 “输出 " 复 选 框 设 
置 为 未 选中 状态 。 在 “筛选 器 ”中 输入 查询 条 件 IS NOT NULL。 

@ 指定 分 组 依据 。 打 开 “ 查 询 设计 器 "菜单 ,选择 “添加 分 组 依据 ”命令 ,默认 情况 下 在 
查询 结果 集 内 出 现 的 列 course. courseno 和 course. cname 将 成 为 GROUP BY 子 句 的 一 部 
分 。 对 于 score. final, 除 了 作为 查询 条 件 外 ,还 需 与 聚合 函数 生成 计算 列 作 为 查询 结果 集中 
的 组 成 部 分 ,因此 需 将 其 再 次 添加 到 网 格 窗 格 中 ,并 将 “输出 ” 复 选 框 设置 为 选中 状态 ,指定 
计算 列 别名 为 average。 

设置 排序 。 在 网 格 窗 格 中 将 score. final 数据 列 的 排序 类 型 设置 为 降序 ,排序 顺序 设 
置 为 1。 

@ 设置 完成 后 单 击 “ 保 存 ” 按 钮 ,在 弹出 的 对 话 框 中 输入 视图 的 名 称 v_course_avg, 单 
击 “ 确 定 ” 按 钮 , 即 完 成 了 创建 视图 的 操作 。 

(6) 利用 Transact-SQL 语句 在 teaching 数据 库 中 创建 视图 v_age, 查 询 年 龄 在 18 周岁 
及 以 上 学 生 的 学 号 、 姓 名、 性 别 、 出 生日 期 和 班级 编号 。 若 该 视图 已 存在 , 则 删除 后 重建 。 

在 “查询 编辑 器 ”中 输入 如 下 程序 代码 并 执行 : 

USE teaching 

GO 

IF EXISTS(SELECT * FROM sysobjects WHERE name = 'v_age'RND type= 'V') 

DROP VIEW v_age 

GO 

CREATE VIEW v_age AS 

SELECT studentno, sname, sex, birthdate, classno 

FROM student 

WHERE year(getdate()) - year(birthdate)>= 18 

GO 

SELECT * FROM v_age 


(7) 利用 Transact-SQL 语句 在 teaching 数据 库 中 创建 视图 v_teacher_course, 包 含 教 
师 编号 .教师 姓名 、 职 称 .课程 号 .课程 名 和 任课 班级 。 
在 “查询 编辑 器 ”中 输入 如 下 程序 代码 并 执行 : 


USE teaching 

GO 

CREATE VIEW v_teacher course RS 

SELECT x. teacherno, tname, prof, cname, classno 

FROM teacher x, course y,teach class z 

WHERE x. teacherno = z. teacherno and y. courseno = z. courseno 
GO 

SELECT * FROM v_teacher_course 
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(8) 利用 Transact-SQL 语句 修改 v_age 的 视图 定义 ,添加 WITH CHECK OPTION 
QO 在 查询 编辑 器 中 输入 如 下 插入 语句 并 执行 : 


USE teaching 

GO 

INSERT INTO v_age 

VALUES( '18138211038', ' 李 静 ', ' 女 ', '2000 -6 一 3', '180802') 
GO 

SELECT * FROM v_age 

SELECT * FROM student 


由 于 新 添加 记录 数据 并 不 符合 视图 定义 的 查询 条 件 , 因 此 查看 视图 v_age 会 发 现 新 插 
入 的 记录 并 不 在 结果 集中 ,但 通过 视图 向 基本 表 中 插入 数据 的 操作 成 功 ,在 student 中 可 以 
查看 到 新 插入 的 记录 。 

@ 修改 视图 定义 的 代码 如 下 : 


ALTER VIEW v_age AS 

SELECT studentno, sname, sex, birthdate, classno 
FROM student 

WHERE year(getdate()) - year(birthdate)>= 18 
WITH CHECK OPTION 


@ 在 添加 了 WITH CHECK OPTION 选项 的 视图 中 执行 如 下 插入 语句 ， 


INSERT INTO v_age 

VALUES( '18138211039', ' 李 琳 琳 ', ' 女 ', '2000 -6 一 3', '180802') 
G0 

SELECT * FROM v_age 

SELECT * FROM student 


由 于 该 视图 创建 了 WITH CHECK OPTION 条 件 约束 , 当 插 入 记录 时 所 有 “年 龄 "不符 
合 条 件 的 记录 无 法 插入 和 修改 ,并 显示 错误 提示 信息 : 


消息 550, 级 别 16, 状态 1, 第 1 行 

试图 进行 的 插入 或 更 新 已 失败 ,原因 是 目标 视图 或 者 目标 视图 所 跨越 的 某 一 视图 指定 了 WITH CHECK 
OPTION, 而 该 操作 的 一 个 或 多 个 结果 行 又 不 符合 CHECK OPTION 约束 。 

语句 已 终止 。 


(9) 通过 视图 v_teacher_course 将 教师 编号 为 t05017 的 教师 职称 更 改 为 “副教授 ”。 
在 “查询 编辑 器 ”中 输入 如 下 程序 代码 并 执行 : 
UPDATE v_teacher course 
SET prof = ' 副 教授 ' 
WHERE teacherno = 't05017" 


GO 
SELECT * FROM teacher 


注意 : 当 视 图 来 自 多 个 基 表 时 ,通常 只 能 对 非 主 属性 进行 修改 操作 。 


(10) 利用 TransactrSQL 语句 删除 创建 的 索引 和 视图 。 
在 “查询 编辑 器 中 输入 如 下 程序 代码 并 执行 ; 

USE teaching 

GO 

DROP INDEX student.UC classno, teacher.UQ tname 


DROP VIEW v_course avg, v_age, v_teacher course 


4. 实验 报告 总 结 

(1) 不 同类 型 索引 的 功能 及 被 查询 优化 器 使 用 的 情况 。 
(2) 视图 与 数据 表 及 查询 的 区 别 。 

(3) 通过 视图 插入 ,修改 、 删 除 基 本 表 中 数据 的 注意 事项 。 


实验 10 存储 过 程 和 触发 器 


1. 实验 目的 

(1) 掌握 存储 过 程 和 触发 器 的 基本 概念 及 功能 。 

(2) 掌握 创建 ,管理 存储 过 程 的 方法 。 

(3) 掌握 创建 ,管理 触发 器 的 方法 。 

2. 实验 预习 与 准备 

主教 材 第 9 章 ,本 书 第 9 章 。 

(1) 存储 过 程 和 触发 器 的 基本 概念 。 

(2) 利用 SQL Server Management Studio 和 Transact-SQL 语句 创建 管理 存储 过 程 。 

(3) 利用 SQL Server Management Studio 和 Transact-SQL 语句 创建 ,管理 触发 器 。 

3. 实验 内 容 及 步 又 

(1) 利用 SQL Server Management Studio 创建 一 个 存储 过 程 ProcNum ,查询 每 个 班级 
中 学 生 的 人 数 , 按 班级 号 升序 排序 。 

@ 启动 SQL Server Management Studio, 在 “对 象 资源 管理 器 ”中 展开 “数据 库 ? 一 
teaching 一 "可 编程 性 ”。 碳 击 “ 存 储 过 程 ? 选 项 ,在 弹出 的 快捷 菜单 中 选择 “新 建 存 储 过程 
命令 。 

@ 在 查询 编辑 器 的 存储 过 程 模板 中 输入 如 下 创建 存储 过 程 的 代码 并 执行 : 

USE teaching 

GO 

CREATE PROCEDURE ProcNum AS 

SELECT classno, COUNT( * ) AS number FROM student 

GROUP BY classno ORDER BY classno ASC 


GO 
EXEC ProcNum 


(2) 利用 Transact-SQL 语句 创建 一 个 带 有 参数 的 存储 过 程 ProcInsert, 向 score 表 插 
人 一 条 选课 记录 ,并 查询 该 学 生 的 姓名 、 选 修 的 所 有 课程 名 称 、 平 时 成 绩 和 期 末 成 绩 。 
Q@ 在 “查询 编辑 器 ”中 输入 如 下 创建 存储 过 程 的 代码 并 执行 : 


USE teaching 
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GO 

CREATE PROCEDURE ProcInsert(@ sno NCHAR(10), @cno NCHAR(6), @daily NUMERIC(6,2), @final 
NUMERIC (6,2)) aS 

INSERT INTO score VALUES(@sno, @cno, @daily, @final) 

SELECT sname, cname, daily, final 

FROM student s, course cv Score sc 

WHERE s. studentno = sc. studentno and c. courseno = sc. courseno and s. studentno = @ sn 


@ 调用 存储 过 程 ProcInsert, 向 score 表 插 入 一 条 选课 记录 。 


DECLARE (@average NUMERIC (6,2) 
EXEC ProcInsert '18135222201', 'c05103',88,90 


(3) 利用 Transact-SQL 语句 创建 一 个 存储 过 程 ProcAvg, 查 询 指定 班级 指定 课程 的 平 
均 分 。 班 级 号 和 课程 名 称 由 输入 参数 给 定 , 计 算出 的 平均 分 通过 输出 参数 返回 。 若 该 存储 
过 程 已 存在 , 则 删除 后 重建 。 

Qa 在 “查询 编辑 器 ”中 输入 如 下 创建 存储 过 程 的 代码 并 执行 : 


USE teaching 
G0 
IF EXISTS(SELECT * FROM sysobjects WHERE name= 'ProcAvg'and type= 'P') 
DROP PROCEDURE ProcAvg 
GO 
CREATE PROCEDURE ProcAvg ( @ classno NCHAR (10), @ cname NCHAR (20)，@ avg NUMERIC (6, 2) 
OUTPUT) AS 
SELECT @avg = AVG(final) 
FROM student s, course cv Score sc 
WHERE s. studentno = sc. studentno and c. courseno = sc. courseno and classno = @classno and cname 
= @cname 


@ 调用 存储 过 程 ProcAvg ,查询 180502 班 中 “C 语言 "课程 的 平均 分 ,并 通过 PRINT 
函数 输出 查询 结果 。 
DECLARE (@average NUMERIC(6,2) 


EXEC ProcAvg '180502', 'C 语言 '，@average OUTPUT 
PRINT '180502 班 中 C 语 言 课程 的 平均 分 为 '+ CAST( @average AS VARCHAR(10)) 


(4) 利用 SQL Server Management Studio 创建 一 个 AFTER 触发 器 trigsex, 当 搬入 或 
修改 student 表 中 性 别 字段 sex 时 ,检查 数据 是 否 只 为 * 男 ”或 “ 女 ”。 

@ 启动 SQL Server Management Studio, 展 开 “ 资 源 管理 器 ”>“ 数 据 库 ”>teaching 习 “ 表 ”。 

@ 选择 student 表 并 展开 , 右 击 “触发 器 ”选项 ,在 弹出 的 快捷 菜单 中 选择 “新 建 触 发 器 ” 
命令 。 

@ 在 “查询 编辑 器 ”的 触发 器 模板 中 输入 如 下 创建 触发 器 的 代码 并 执行 : 

USE teaching 

GO 

CREATE TRIGGER trigsex ON student AFTER INSERT, UPDATE AS 

BEGIN 


DECLARE @ sex char(2) 
SELECT (@ sex = sex FROM inserted 


IF @sex<>' 男 'and @sex<>' 女 ' 
BEGIN 
RAISERROR( "性别 只 能 为 男 或 女 ', 16,1) 
ROLLBACK 
END 
END 


@ 执行 如 下 插入 请 句 : 


INSERT INTO student( studentno, sname, sex, birthdate, classno) 
VALUES( '18138211039', ' 李 琳 琳 ', 'F', '2000 -6-3','180802') 


由 于 创建 了 触发 器 trigsex, 当 插入 和 更 新 记录 时 所 有 “性 别 ” 不 符合 条 件 的 记录 无 法 实 
现 操作 ,并 显示 错误 提示 信息 : 


消息 50000, 级别 16, 状态 1, 过 程 trigsex, 第 7 行 
性 别 只 能 为 男 或 女 

消息 3609, 级 别 16, 状态 1, 第 1 行 

事务 在 触发 器 中 结束 . 批 处 理 已 中 止 。 


(5) 利用 Transact-SQL 语句 创建 一 个 AFTER 触发 器 trigforeign, 当 向 score 表 中 搬 
入 或 修改 记录 时 ,如 果 插入 或 修改 的 数据 与 student 表 中 数据 不 匹配 , 即 没 有 对 应 的 学 号 存 
在 , 则 将 此 记录 删除 。 

@ 删除 student 和 score 表 之 间 的 外 键 约束 FK_student_score, 程 序 代 码 如 下 : 


ALTER TABLE score 
DROP CONSTRAINT FK_score_student 


外 键 约束 强制 外 键 表 中 列 的 取 值 只 能 为 NULL 或 等 于 被 引用 表 中 某 个 元 组 的 主键 值 ， 
且 约 束 的 优先 级 高 于 触发 器 ,因此 当 外 键 约束 与 所 创建 的 trigforeign 触发 器 同时 存在 时 , 系 
统 优先 考虑 外 键 约束 。 若 希望 创建 的 触发 器 发 挥 作用 , 则 需 手 动 删除 已 存在 的 外 键 约束 。 
@ 在 “查询 编辑 器 "中 输入 如 下 创建 触发 器 的 代码 并 执行 : 


USE teaching 
GO 
CREATE TRIGGER trigforeign ON score AFTER INSERT, UPDATE AS 
BEGIN 
DECLARE @sno char(5) 
SELECT @ sno = studentno FROM inserted 
IE NOT EXISTS(SELECT * FROM student WHERE studentno = @sno) 
BEGIN 
RAISERROR( "该 学 生 信息 不 存在 ,不 允许 插入 选课 信息 …16,1) 
ROLLBRCK 
END 
END 


@ 执行 如 下 插入 语句 : 


INSERT INTO score( studentno, courseno, daily, final) 
VALUES( '18138211039', 'c05109', 88,90) 
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由 于 创建 了 触发 器 trigforeign, 当 插入 和 更 新 记录 时 所 有 “学 号 "不 符合 条 件 的 记录 无 
法 实现 操作 ,并 显示 错误 提示 信息 : 


消息 50000, 级 别 16, 状态 1, 过 程 trigforeign, 第 7 行 
该 学 生 信息 不 存在 ,不 允许 插入 选课 信息 

消息 3609, 级别 16, 状 态 1, 第 1 行 

事务 在 触发 器 中 结束 . 批 处 理 已 中 止 。 


(6) 利用 TransactrSQL 语句 创建 一 个 AFTER 和 触发 器 trigclassname, 当 向 class 表 中 
插 和 人 或 修改 数据 时 ,如 果 出 现 班级 名 称 重复 则 回 滚 事务 。 若 该 触发 器 已 存在 , 则 删除 后 
Qa 在 “查询 编辑 器 ”中 输入 如 下 创建 触发 器 的 代码 并 执行 : 


USE teaching 
GO 
IF EXISTS(SELECT x FROM sysobjects WHERE name = 'trigclassname' RND type = 'TR') 
DROP TRIGGER trigclassname 
GO 
CREATE TRIGGER trigclassname ON class AFTER INSERT, UPDATE RS 
BEGIN 
DECLARE @name CHAR(10) 
SELECT @name = inserted. classname FROM inserted 
IE EXISTS ( SELECT classname FROM class WHERE classname = (@name GROUP BY classname HAVING 
COUNT(* )>=2 ) 
BEGIN 
RRISERROR( ' 班 级 名 称 重复 ,不 能 插入 ',16, 1) 
ROLLBACK 
END 
END 


对 于 AFTER 触发 器 而 言 ,判断 是 否 出 现 姓 名 重复 的 Transact-SQL 语句 仅 在 插入 和 修 
改 操作 成 功 执行 时 才 被 触发 。 当 向 student 表 中 插入 或 修改 数据 时 ,新 的 记录 将 同时 被 添 
加 到 数据 表 student 和 临时 表 inserted 中 ,因此 仅 当 student 表 中 至 少 存在 两 条 记录 的 姓名 
字段 与 inserted 表 相 同 , 方 可 确认 插入 或 修改 操作 出 现 姓 名 重复 ,事务 需 回 滚 。 

@ 执行 如 下 插入 语句 : 


INSERT INTO class(classno, classname, department, monitor) 

VALUES( '180602', ' 计 算 机 ', ' 计 算 机 学 院 ',' 马 文 韭 ') 

由 于 创建 了 触发 器 trigclassname, 当 插入 和 更 新 记录 时 所 有 “班级 名 称 ” 重 复 的 记录 无 
法 实现 操作 ,并 显示 错误 提示 信息 : 

消息 50000, 级别 16, 状态 1, 过程 trigclassname, 第 7 行 

班级 名 称 重复 ,不 能 插入 

消息 3609, 级 别 16, 状态 1, 第 1 行 

事务 在 触发 器 中 结束 . 批 处 理 已 中 止 。 

4. 实验 报告 总 结 

(1) 存储 过 程 中 输出 参数 与 输入 参数 在 定义 ,调用 时 的 区 别 。 


(2) 触发 器 INSERT.DELETE 和 UPDATE 操作 与 临时 表 inserted 和 deleted 的 关系 。 
(3) 存储 过 程 与 触发 器 的 联系 和 区 别 。 


实验 11 事务 和 镇 


1. 实验 目的 
(1) 掌握 事务 和 锁 的 基本 概念 。 
(2) 掌握 事务 的 定义 .管理 及 利用 事务 进行 数据 处 理 的 方法 。 
(3) 了 解 SQL Server 2016 的 并 发 控制 及 锁 的 管理 等 相关 技术 。 
2. 实验 预习 与 准备 
主教 材 第 10 章 ,本 书 第 10 章 。 
(1) 事务 的 特点 和 分 类 。 
(2) 事务 的 启动 .保存 .提交 、 回 滚 和 蔗 套 定义 。 
(3) 定义 隔离 级 别 实现 事务 访问 资源 和 数据 的 隔离 。 
(4) 锁 的 类 型 和 管理 。 
3. 实验 内 容 及 步 又 
(1) 定义 一 个 事务 ,在 teaching 数据 库 的 student 表 和 score 表 中 新 增 一 名 学 生 的 基本 
信息 记录 和 选课 记录 ,并 提交 该 事务 。 

Q@ 定义 事务 ,在 “查询 编辑 器 ”中 输入 如 下 程序 并 执行 : 
USE teaching 
GO 
DECLARE @TranName VARCHAR( 20); 
SELECT @TranName = 'Insert_ Info'; 
BEGIN TRAN @TranName; 

INSERT INTO student 

VALUES ( '18122221326'，' 李 杰 '，' 男 '，'2000 -2 一 3','180501', 754, '13456734522','1ijie@ sina. 

); 
eh INTO score( studentno, courseno) 


VALUES ('18122221326', 'c05109'); 
COMMIT TRAN @TranName; 


@ 验证 结果 。 


SELECT * FROM student WHERE studentno = '18122221326 

SELECT * FROM score WHERE studentno = '18122221326 

(2) 定义 一 个 事务 ,在 teaching 数据 库 向 score 表 中 增加 学 号 为 18122221326 学 生 的 选 
课 记 录 ,并 回 滚 该 事务 。 

@ 定义 事务 ,在 “查询 编辑 器 "中 输入 如 下 程序 并 执行 : 


USE teaching 
GO 
BEGIN TRAN Insert_score 
INSERT INTO score 第 
VALUES ('18122221326', 'c05103',90,87); 18 
ROLLBACK TRAN Insert_score; 章 
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@ 验证 结果 。 
SELECT * FROM score WHERE studentno = '18122221326， 


(3) 定义 一 个 事务 ,将 student 表 中 学 号 为 18122221326 的 学 生性 别 修改 为 “ 女 ”, 并 设 
置 一 个 保存 点 ,然后 将 score 表 中 学 号 为 18122221326 的 学 生 期 末 成 绩 修改 为 88 ,最 后 回 滚 
到 事务 的 保存 点 ,提交 事务 。 

J@ 定义 事务 ,在 “查询 编辑 器 ?中 输入 如 下 程序 并 执行 : 


USE teaching 
GO 
BEGIN TRAN 
UPDATE student 
SET sex = ' 女 ' 
WHERE studentno = '18122221326'; 
SAVE TRAN savepoint; 
UPDATE score 
SET final = 88 
WHERE studentno = '18122221326'; 
ROLLBACK TRAN savepoint; 
COMMIT TRAN 


@ 验证 结果 。 


SELECT * FROM student WHERE studentno = '18122221326 
SELECT * FROM score WHERE studentno = '18122221326 


(4) 使 用 隐 式 事务 完成 对 score 表 的 操作 。 
在 “查询 编辑 器 ”中 输入 如 下 程序 并 执行 : 


USE teaching 

GO 

SET IMPLICIT_TRANSACTIONS ON; 
SELECT * FROM score WHERE studentno 
一 第 一 个 隐 式 事务 开始 

UPDATE score 

SET final = 88 

WHERE studentno = '18122221326'; 
SELECT * FROM score WHERE studentno '18122221326'; 

COMMIT TRAN -提交 第 一 个 隐 式 事务 
一 第 二 个 隐 式 事务 开始 

UPDATE score 

SET daily= 90 

WHERE studentno = '18122221326'; 

SELECT * FROM score WHERE studentno '18122221326'; 

ROLLBACK TRAN -- 回 滚 第 二 个 隐 式 事务 
SELECT * FROM score WHERE studentno "18122221326 7 

SET IMPLICIT_TRANSACTIONS OFF; 


(5) 使 用 嵌 套 事务 完成 对 score 表 的 操作 。 
在 “查询 编辑 器 ”中 输入 如 下 程序 并 执行 : 


"18122221326 7 


USE teaching 
GO 
BEGIN TRAN outer trans 
BEGIN TRAN inner trans 
SELECT * FROM score WHERE studentno = '18122221326'; 
UPDATE score 
SET final = 95 
WHERE studentno = '18122221326'7 
SELECT * FROM score WHERE studentno = '18122221326'; 
COMMIT TRAN inner trans; -- 提交 嵌 套 内 层 事务 
UPDATE score 
SET daily= 90 
WHERE studentno = '18122221326'; 
SELECT * FROM score WHERE studentno = '18122221326'; 
ROLLBRCK TRAN outer trans; =-- 回 滚 外 层 事务 
SELECT * FROM score WHERE studentno = '18122221326'; 


(6) SQL Server 检测 和 处 理 死 锁 。 
@ 打开 一 个 “查询 编辑 器 ”, 输 入 如 下 程序 并 执行 : 


USE teaching 
GO 
BEGIN TRAN transl 
UPDATE score 
SETdaily= 90 
WHERE studentno = '18122221326'; 
注意 ,不 要 提交 事务 transl 。 
@ 打开 第 二 个 “查询 编辑 器 ”, 输 入 如 下 程序 并 执行 : 
USE teaching 
GO 
BEGIN TRAN trans2 
DELETE FROM student 
WHERE studentno = '18122221326 


DELETE FROM score 
WHERE studentno = '18122221326 


由 于 在 查询 1 中 的 事务 没有 提交 ,因此 事务 trans2 将 被 阻塞 。 
@ 重新 打开 第 一 个 “查询 编辑 器 ”, 输 入 如 下 程序 并 执行 : 


UPDATE student 
SET sex = ' 男 ' 
WHERE studentno = '18122221326'; 


其 中 一 个 事务 被 取消 ,并 且 显 示 如 下 错误 提示 信息 : 


消息 1205, 级 别 13, 状态 51, 第 2 行 

事务 (进程 ID 54) 与 另 一 个 进程 被 死 锁 在 锁 资 源 上 ,并 且 已 被 选 作 死 锁 牺 牲 品 . 请 重新 运行 该 事务 。 

@ 在 此 过 程 中 ,每 一 步 运行 结束 均 可 通过 系统 视图 sys. dm_tran_locks 查看 锁定 资源 全 
的 相关 信息 。 章 
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4. 实验 报告 总 结 

(1) 显 式 事务 和 隐 式 事务 的 区 别 及 应 用 。 
(2) 嵌 套 事务 处 理 中 回 深 的 使 用 。 

(3) 并 发 数据 访问 引发 的 问题 及 解决 方案 。 


实验 12 SQL Server 2016 的 安全 管理 


1. 实验 目的 

(1) 了 解 SQL Server 2016 的 安全 架构 。 

(2) 掌握 以 服务 器 为 主体 的 安全 管理 的 基本 操作 。 

(3) 掌握 以 数据 库 为 主体 的 安全 管理 的 基本 操作 。 

(4) 掌握 对 用 户 进 行 权 限 管理 的 常用 操作 。 

2. 实验 预习 与 准备 

预习 主教 材 第 11 章 和 本 书 第 11 章 的 内 容 。 

(1) SQL Server 2016 的 安全 机 制 。 

(2) 管理 服务 器 范围 ,数据库 范围 安全 性 。 

(3) 权限 管理 。 

3. 实验 内 容 及 步 又 

(1) 利用 SQL Server Management Studio 创建 登录 。 创 建 一 个 SQL Server, 登 录 名 为 
ziyan, 密 码 为 jsj1802。 

在 SQL Server Management Studio 中 展开 “对 象 资源 管理 器 ”一 “安全 性 ” 子 目 录 , 布 
击 “ 登 录 名 ”, 在 弹出 的 快捷 菜单 中 选择 “新 建 登 录 名 ”命令 。 

@ 在 “登录 名 -新 建 ? 界 面 上 设置 登录 名 为 ziyan、 身 份 验证 模式 为 SQL Server 身份 验 
证 、 密 码 为 jsj1802、 默 认 数据 库 (teaching) 和 语言 的 类 型 等 参数 后 ,如 图 18-7 所 示 。 


默认 语 高 (5) 


18-7 创建 登录 名 


@ 选择 “服务 器 角色 ”选项 卡 ,选择 服务 器 角色 sysadmin。 
@ 选择 “用 户 映射 "选项 卡 , 选 择 teaching 数据 库 , 用 户 名 为 ziyan ,默认 架构 为 dbo, 如 
图 18-8 所 示 。 


| 号 由 本 7 四 痢 助 


ReportServerTenpDB 
student 


tempdb 
testOl 
test02 
test03 


已 启用 Guest 帐户 - teaching 


| 堵 据 库 角色 成 员 身 份 (8): teaching 
db_accessadnin 

估 和 器 womese | 日 db_backupoperator 

db_datareader 

db_datarriter 

| Obanadnin 

| [db_denydatareader 

| [OD db_denydatarriter 

| 回 db_owner 

| OD db_secwrityadnin 

| 口 jsile 

回 publie 


潜 :ypeomesowninistrst| 日 
一 9 查看 笑 接 划 性 


18-8 用 户 映射 


@ 其 他 选项 卡 可 以 选择 默认 设置 ,然后 单 击 “脚本 "按钮 ,可 以 在 “查询 设计 器 ?中 查看 
创建 登录 的 代码 。 

@ 单 击 “ 确 定 ” 按 钮 即 可 完成 登录 名 ziyan 的 创建 。 

@ 分 别 展开 “安全 性 ?一 “登录 名 ? 子 目录 和 teaching 数据 库 的 “安全 性 ”一 “用 户 ” 子 目 
录 查 看 登录 名 ziyan 和 用 户 ziyan。 

(2) 练习 利用 登录 名 ziyan 连接 服务 器 。 

Oz 布 击 SQL Server Management Studio 中 的 实例 ,在 弹出 快捷 菜单 中 选择 “连接 ” 
命令 。 
@ 在 弹出 的 “连接 到 服务 器 界面 中 选择 “SQL Serve 身份 验证 ”, 然 后 输入 登录 名 ziyan 
和 密码 jsj1802, 如 图 18-9 所 示 。 

@ 单 击 “连接 ?按钮 可 以 测试 连接 是 否 成 功 。 若 不 成 功 ,会 出 现 错误 信息 提示 框 。 

@ 若 测试 成 功 , 则 会 在 “对 象 资源 管理 器 "中 出 现 连接 成 功 的 信息 。 

(3) 练习 为 teaching 数据 库 建立 用 户 ziyan, 并 为 其 赋予 查询 student 表 的 权限 。 

@ 展开 数据 库 teaching 一 “安全 性 ”>“ 用 户 ” 子 目录 , 右 击 数据 库 用 户 ziyan。 

@ 在 弹出 的 快捷 菜单 中 选择 “属性 ”选项 ,打开 “数据 库 用 户 -ziyan” 对 话 框 ,在 属性 对 话 
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SQL Server 


服务 器 类 型 (7) 


选项 (0) ?> 


18-9 连接 到 服务 器 


框 中 选择 “安全 对 象 "选择 卡 。 

@ 单 击 “搜索 ”按钮 ,打开 “添加 对 象 " 对 话 框 , 单 击 “ 特 定 对 象 ”, 并 单 击 “ 确 定 ” 按 钮 , 打 
开 * 选 择 对 象 " 对 话 框 。 

@ 在 “选择 对 象 ” 对 话 框 中 单 击 对 象 类 型 ”", 打 开 “ 选 择 对 象 类 型 "对 话 框 。 

@ 在 “选择 对 象 类 型 "对 话 框 中 选中 “ 表 ”, 如 图 18-10 所 示 , 并 单 击 “ 确 定 ” 按 钮 。 在 “ 选 
择 对 象 " 对 话 框 中 单 击 “ 浏 览 ” 按 钮 ,会 打开 “查找 对 象 " 对 话 框 。 


后 丰 对 称 守 钥 S 


本 J 了 广 击 


18-10 选择 对 象 类 型 


@ 在 “查找 对 象 "对 话 框 中 选中 student 数据 表 , 如 图 18-11 所 示 。 然 后 单 击 两 次 “ 确 
定 ? 按 钮 ,返回 数据 库 用 户 属 性 窗口 。 

@ 在 选择 结果 对 话 框 中 选中 SELECT 权限 对 应 的 “授予 " 复 选 框 ,如 图 18-12 所 示 。 然 
后 单 击 “ 确 定 ” 按 钮 , 即 完 成 了 此 题 的 要 求 。 

重复 前 面 的 过 程 ,选择 不 同 的 操作 选项 ,可 以 做 进一步 的 练习 。 同 时 在 操作 过 程 中 
可 以 单 击 “ 脚 本 ”按钮 ,查看 当前 设置 的 脚本 代码 。 

(4) 利用 Transact-SQL 语句 完成 下 面 的 操作 。 


USE teaching 


匹配 的 对 象 0D): 

名 称 
加 [dbo]. [olass] 
国 [dbo]. [count1] 


[dbo]. [expic] 


日 
回 [dbo]. [MSpeer_conflictdetectionconfigrequest] 
回 [dbo]. DrSpeer_conflictdetectionconfigr esponse] 
国 [dbo]. DEpeer_lsns] 


18-11 选择 对 象 


dbo. class 的 权限 (F) 


喇 训 woncse 号 式 有效 
权限 


名 5nencovwaiueee 图 [4 入 
于 查 得 按司 性 下 看 定义 


18-12 ”对 选择 对 象 授予 权限 
GO 


-- 将 对 数据 库 teaching 中 score 表 的 SELECT 权限 授予 数据 库 用 户 USER 179 
GRANT SELECT ON score TO USER 


一 -拒绝 USER 对 score 表 中 courseno 列 的 SELECT 权限 


第 
DENY SELECT(courseno) ON score TO USER 18 
=-- 撤销 USER 对 score 表 的 SELECT 权限 章 
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REVOKE SELECT ON score FROM USER 
一 在 teaching 数据 库 中 创建 数据 表 的 权限 授予 用 户 USER 


GRANT CREATE TABLE TO USER2 

4. 实验 报告 总 结 

(1) SQL Server 2016 系统 的 安全 机 制 的 优 缺 点 。 
(2) 服务 器 .数据库 和 对 象 权 限 的 关系 。 

(3) 授予 .撤销 和 拒绝 权限 的 处 理 机 制 。 


实验 13 备份 和 恢复 


1. 实验 目的 
(1) 了 解 备份 和 恢复 数据 库 的 备份 策略 的 选择 。 
(2) 掌握 备份 数据 库 的 基本 操作 。 
(3) 掌握 恢复 数据 库 的 基本 操作 。 
2. 实验 预习 与 准备 
预习 主教 材 第 12 章 和 本 书 第 12 章 的 内 容 。 
(1) 备份 和 还 原 的 时 机 和 类 型 。 
(2) 备份 策略 的 选择 。 
(3) 备份 数据 库 的 方法 和 步骤 。 
(4) 还 原 数 据 库 的 方法 和 步骤 。 
3. 实验 内 容 及 步 又 
(1) 练习 使 用 SQL Server Management Studio 创建 数据 库 teaching 的 完全 备份 .差异 备份 。 
Q@ 完整 数据 库 备 份 。 在 SQL Server Management Studio 的 “对 象 资源 管理 器 ”窗口 中 
选择 “数据 库 ”>teaching 子 目录 。 
@ 右 击 teaching 数据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “备份 "命令 ,弹出 “备份 数 
据 库 ”对 话 框 ,如 图 18-13 所 示 ,进行 如 下 操作 : 
。 选择 要 备份 的 数据 库 teaching。 
。 选择 要 备份 的 类 型 。 在 “备份 类 型 "下 拉 列 表 框 中 选择 “完整 ”选项 。 
。 设置“ 介质 选项 ”的 “备份 集 " 信 息 。 在 “名 称 ” 文 本 框 中 输入 “teaching 完整 备份 ”; 在 
“说 明 " 文 本 框 中 输入 “完整 备份 试验 ”。 
。 在 “在 以 下 天 数 后 "文本 框 中 可 以 输入 的 范围 为 0~99 999, 如 果 为 0 则 表示 不 过 期 。 
备份 集 过 期 后 会 被 新 的 备份 覆盖 。 这 里 就 设置 为 0。 
。 设置 备份 存放 位 置 。 默 认 是 备份 到 D:\sqlprogram\ teaching_backup_2018 02 27 _ 
102455_2538574。 
@ 其 他 选项 选择 默认 设置 。 单 击 “ 确 定 ” 按 钮 ,开始 备份 数据 库 teaching。 至 此 ,数据 
库 teaching 的 完全 备份 完成 。 
@ 也 可 以 单 击 图 18-13 所 示 界 面 中 的 “添加 ”按钮 添加 备份 路 径 。 在 弹出 的 “选择 备份 
目标 ”对 话 框 中 选择 “备份 设备 ”下 的 devicel ,如 图 18-14 所 示 。 
@ 单 击 “ 确 定 ” 按 钮 ,返回 图 18-13 所 示 界 面 。 若 要 查看 或 选择 高 级 选项 , 则 在 “选项 ” 
选项 卡 中 进行 设计 。 然 后 单 击 “ 确 定 ” 按 钮 ,也 可 完成 完整 数据 库 备份 。 


服务 器 
L637CEYPESYYCSG 内 容 (C0) 


沸 :onmncaowaiu strat 
对 查看 注 接 原 性 


就 绪 


18-13 ”创建 完整 数据 库 备份 


国 过 备份 目标 
选择 文件 或 备份 设备 作为 备份 目标 。 您 可 以 为 常用 文件 创建 备份 设备 。 


碰 盘 上 的 目标 


O 〇 文件 名 @) : 
‘rogram Piles\licrosoft SQL ServerWISSQLI3.JSSQLSERVERVISSQL\Backup\ | 到 | 


@ 备份 设备 (E); 
devieel 


18-14 选择 备份 设备 


@ 数据 库 差异 备份 。 重 复 第 、@ 步 ,选择 要 备份 类 型 “差异 备份 ", 即 在 “备份 类 型 "下 
拉 列 表 框 中 选择 “差异 ”。 单 击 “ 确 定 ” 按 钮 ,可 完成 差异 数据 库 备 份 。 
@ 事务 日 志 备 份 。 重 复 第 、@ 步 ,选择 要 备份 类 型 “事务 日 志 备 份 ”, 即 在 “备份 类 型 ” 
下 拉 列 表 框 中 选择 “事务 日 志 ”。 单 击 “ 确 定 ” 按 钮 ,可 完成 差异 数据 库 备 份 。 
@ 在 备份 过 程 中 ,车 单 击 “ 脚 本 ”按钮 ,还 可 以 在 “查询 设计 器 ”中 观察 各 种 备份 的 脚本 
代码 。 
(2) 练习 创建 数据 库 teaching 的 文件 和 文件 组 备份 。 世 
@ 在 SQL Server Management Studio 的 “对 象 资源 管理 器 ”窗口 中 选择 “数据 库 ? 一 章 
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teaching 子 目录 。 

@ 右 击 teaching 数据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”备份 ”命令 ,弹出 “备份 数 
据 库 ”对话 框 。 

@ 选择 要 备份 的 数据 库 teaching ,并 选择 “文件 和 文件 组 ”备份 选项 ,弹出 如 图 18-15 所 
示 的 “选择 文件 和 文件 组 ”对 话 框 ,选择 主 文件 teaching。 


18-15 文件 备份 选择 


@ 其 他 选项 选择 默认 设置 , 单 击 “ 确 定 ” 按 钮 ,数据 库 文件 teaching 的 备份 生成 。 

(3) 练习 利用 差异 备份 还 原 数 据 库 student。 

在 SQL Server Management Studio 中 利用 差异 备份 还 原 数据 库 , 系 统 首先 要 对 当前 
数据 库 事务 日 志 进 行 一 次 备份 ,然后 接着 进行 还 原 操作 ,如 图 18-16 所 示 。 

@ 启动 SQL Server Management Studio, 在 "对象 资 源 管理 器 ”窗口 中 选择 “数据 库 ” 一 
student 子 目录 。 右 击 该 数据 库 , 在 弹出 的 快捷 菜单 中 选择 “任务 ”>“ 还 原 ”>“ 数 据 库 ” 命 
令 , 弹 出 “还 原 数 据 库 ” 对 话 框 , 单 击 “ 时 间 线 ”按钮 ,如 图 18-17 所 示 。 选 择 时 间 线 的 指示 针 ， 
可 以 将 数据 库 还 原 到 指定 时 间 。 

@ 根据 不 同 的 还 原 情况 选择 不 同 的 选择 项 。 

。 选择 目标 数据 库 student。 

。 选择 目标 时 间 点 。 如 果 备 份 文件 或 备份 设备 里 的 备份 集 很 多 ,还 可 以 选择 “目标 时 
间 点 ”, 只 要 有 事务 日 志 备 份 支持 ,就 可 以 还 原 到 某 个 时 间 的 数据 库 状 态 。 这 里 采用 
默认 值 “ 最 近 状 态 ”。 

。 选择 还 原 的 源 。 在 该 区 域 里 可 以 指定 用 于 还 原 的 备份 集 的 源 和 位 置 。 在 “目标 数据 
库 ? 下 拉 列 表 框 中 选择 student。 

。 选择 用 于 还 原 的 备份 集 。 必 须 先 选择 完整 备份 ,再 选择 差异 备份 文件 。 


晤 还 原 数据 库 - student 一 口 x 
正在 还 原 : CNProgram Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Backup\student LogBackup - IE 停止 


Microsoft SQL Server Management Studio XX 


【站 成 功 还 原 了 数据 库 student 


LG37CEYPE9YWCSG 
[LG37CEYPE9YWCSGVAdmin 
istrator] 


查看 连接 属性 
| > 


18-16 利用 差异 备份 还 原 数据 库 


〇 特定 日 期 和 时 间 (8) 
日 期 () ‘2018/ 2/28 
时 间 (D): 20:43:25 


图 18-17 “还 原 数据 库 ? 的 时 间 线 设置 
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@ 设置 完毕 后 , 单 击 * 确 定 "按钮 完成 还 原 操作 。 
@@ 若 单 击 “ 脚 本 ”按钮 ,可 以 得 到 参数 丰富 的 代码 。 
(4) 利用 Transact-SQL 语句 完成 下 列 操作 : 


-- 新建 名 为 Device2 的 备份 设备 并 映射 成 为 磁盘 文件 "D:\DATA\Device2. BAK" 
EXEC sp_addumpdevice 'disk', 'Device2', 'D:\DATA\Device2. BAK' 

一 删除 创建 的 备份 设备 Device2 

EXEC sp_dropdevice 'Device2 

一 创建 一 个 新 的 备份 设备 Device3, 并 将 数据 库 teaching 完全 备份 到 Device3 上 


程序 清单 如 下 : 


USE teaching 

GO 

EXEC sp_addumpdevice 'disk', 'Device3', 'D:\DATA\Device3. BAK' 
GO 

BACKUP DATABASE teaching TO Device3 

-- 从 Devicel 备份 设备 进行 还 原 完整 数据 库 操作 ,还 原 以 后 的 数据 库 名 称 为 TEST1 
USE MASTER 

G0 

RESTORE DATABASE TEST1 

FROM Devicel 

WITH REPLACE 


4. 实验 报告 总 结 
(1) SQL Server 2016 数据 库 的 备份 策略 选择 。 
(2) 还 原 数据 库 需 要 注意 的 问题 。 


实验 14 系统 自动 化 任务 管理 


1. 实验 目的 

(1) 掌握 SQL Server 代理 的 启动 和 配置 操作 。 

(2) 学 会 创建 和 管理 作业 、 警 报 和 操作 员 。 

(3) 学 会 创建 维护 计划 。 

2. 实验 预习 与 准备 

预习 主教 材 第 13 章 和 本 书 第 13 章 。 

(1) SQL Server 代理 的 基本 操作 。 

(2) 作业 、 警 报 和 操作 员 的 关系 。 

(3) 创建 维护 计划 的 操作 步 又。 

3. 实验 内 容 及 步 又 

(1) 配置 SQL Server 代理 

@ 启动 并 右 击 SQL Server 代理 ,在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 。 
@) 弹出 “SQL Server 代理 属性 ”界面 ,如 图 18-18 所 示 。 

@ 依次 选择 “常规 “高 级 “警报 系统 “作业 系统 "等 选项 卡 ,查看 和 设置 各 个 选项 。 
@ 设置 完毕 , 单 击 “ 确 定 ” 按 钮 即 可 。 


目 SQL Server 代理 尾 性 - LG37CEYPE9YWCSG 


电 提 本 ” 四 者 助 


代理 服务 
服务 状态 正在 运行 


回 SQL Server 意外 停止 时 自动 重新 启动 (9) 


回 SRL Server 代理 意外 停止 时 自动 重新 启动 (6) 
错误 日 志 
文件 名 (F): 

c:\Program Files\icrosoft SQL Server WSSQLI3. WSSQLSERVERVSSQL\Loe\SQLAGENT. OW) 
口 包含 执行 跟踪 消息 (I) 

写 入 om 文件 人; 


Net send 收 件 人 (0): 


服务 器 
LE37EEYPP9YWCSG 


总 : 
L637CEYPESYWCSG\Adninistrat 


避 查看 连接 属性 


图 18-18 ”SQL Server 代理 属性 


(2) 使 用 SQL Server Management Studio 创建 作业 

@ 展开 “SQL Server 代理 ? 子 目录 , 右 击 “ 作 业 ”, 在 弹出 的 快捷 菜单 中 选择 “新 建 作 业 ” 
命令 ,出现 * 新 建 作业 ?界面 以 及 “常规 “步骤 ?等 6 个 选项 卡 。 

@ 在 “常规 ”选项 卡 中 可 以 输入 该 作业 的 名 称 job001、 所 有 者 ziyan、 类 别 “ 数 据 库 维 护 ” 
以 及 说 明 等 信息 ,如 图 18-19 所 示 。 

@ 在 “步骤 ”选项 卡 中 单 击 “ 新 建 "按钮 ,进入 “新 建 作业 步骤 ”界面 ,出 现 “ 常 规 ”" 和 “高 
级 ”两 个 选项 卡 。 可 以 在 该 界面 中 定义 作业 步骤 的 详细 信息 。“ 常 规 ” 选 项 卡 用 于 输入 作业 
步骤 的 基本 信息 ,如 图 18-20 所 示 。 

@ 在 “高 级 "选项 卡 中 可 以 设置 该 作业 步骤 执行 成 功 或 失败 后 的 行为 、 重 试 次 数 、 存 放 
结果 文件 的 位 置 、 是 否 覆 盖 结果 文件 中 原 有 的 信息 ,以 及 作为 哪 一 个 用 户 账户 运行 等 ,如 
图 18-21 所 示 。 

@ 在 “计划 ”选项 卡 中 单 击 “ 新 建 ”" 按 钮 , 则 出 现 “ 新 建 作 业 计 划 ” 界 面 ,输入 
job001planl 。 在 该 界面 中 可 设置 作业 的 调度 方式 。 

@“ 和 警报 ?选项 卡 用 于 管理 警报 。 在 “通知 ?选项 卡 中 可 以 设置 包括 使 用 电子 邮件 、 使 用 
呼叫 、 使 用 网 络 消息 等 方式 通知 操作 员 。 还 可 以 选择 当 该 作业 完成 之 后 ,自动 删除 该 作业 。 

@ 在 “目标 ”选项 卡 中 可 以 选择 目标 为 本 地 服务 器 或 多 台 服 务 器 。 单 击 “ 脚 本 ”按钮 可 
以 查看 脚本 代码 。 

@ 单 击 “ 确 定 ” 按 钮 , 则 完成 作业 job001 的 创建 操作 。 
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ET 
和 名称); 
所 有 者 (0): 
类 别 (C): 


说 明 (D) 20180301 第 001 个 数据 库 维护 作业 


| 


服务 器 
L637CEYPE9WCSG 回 


:ypeomesowniniste at 
巴 ] 查看 连接 略 性 


图 18-19 “新 建 作业 ”界面 中 的 “常规 ”选项 卡 


在 创建 作业 时 还 可 以 单 击 “ 脚 本 ”按钮 获得 脚本 。 如 果 需 要 重新 创建 作业 ,直接 打开 作 
业 的 脚本 文件 并 执行 即 可 。 

还 可 以 在 作业 子 目录 中 右 击 job001 作业 ,通过 弹出 菜单 对 作业 进行 管理 。 

(3) 创建 警报 以 响应 SQL Server 错误 。 

QO@ 展开 “SQL Server 代理 ”, 然 后 右 击 “ 警 报 ” 选 项 ,从 弹出 的 快捷 菜单 中 选择 “新 建 警 
报 "命令 ,将 出 现 “ 新 建 警报 属性 ”界面 。 

@ 在 “常规 ”选项 卡 中 指定 警报 的 名 称 Alert11, 类 型 选择 “SQL Server 事件 警报 ”, 事 件 
警报 定义 等 ,如 图 18-22 所 示 。 

@ 在 “响应 选项 卡 中 可 以 选择 执行 作业 job001 ,并 以 电子 邮件 方式 通知 操作 员 刘 向 蓝 
等 信息 。 

@ 在 “选项 ”选项 卡 中 设置 警报 的 发 送 方式 等 附加 内 容 , 如 电子 邮件 等 ,然后 单 击 “ 确 
定 ” 按 钮 。 

警报 的 执行 过 程 中 如 果 发 生 了 指定 的 触发 错误 , 则 触发 Alertl 警报 ,该 警报 执行 
Job001 作业 ,并 且 通 知 刘 向 蓝 操作 员 。 

(4) 创建 操作 员 并 为 操作 员 分 配 警 报 。 

@ 在 “对 象 资源 管理 器 "中 展开 “SQL Server 代理 ” 子 目 录 , 右 击 “ 操 作 员 ” 选 项 ,在 弹出 
的 快捷 菜单 中 选择 “新 建 操作 员 ” 命 令 。 

@ 在 弹出 的 “新 建 操作 员 ” 界 面 中 的 “常规 ”选项 卡 中 输入 操作 员 名 称 user。 


服务 器 
L53TCEYPP9YWCSG 


连接 
L637CEYFE9YWCSG\Adninistrat 


圣 查看 这 接 导 性 


号 M7 四 才 


步 玉 名 称 (5)- 


jobOO1_testl 


类 型 (7); 


Transset-SQL 脚本 (T-SQL) 


teaching 


[se teaching 
加 


To 学 生 选 主 统 计 
IFROM score 
|GROUP BY studentno 


|SELECT studentno, 3 罗 “ 选 课 数目 ', SUM(finel) AS“ 挟 


18-20 “新 建 作业 步骤 ”界面 中 的 “常规 ”选项 卡 


服务 器 
1L637CEYPE9YWCSG 


连接 
537CEYPE9YWCSGWAdninistrat 


于 查 查 广 控 必 性 


a] 


成 zh 时 要 执行 的 操作 (S) 


转 到 下 一 步 


重 试 次 数 (B) 
本 


失败 时 要 执行 的 操作 (F): 


Transact-S9L 脚本 (T-S9L) 


输出 文件 () 


将 输出 追加 到 现 有 文件 (A) 
口 记录 到 表 (O) 
站 将 输出 追加 到 表 中 的 现 有 条 目 (T) 
口 在 历史 记录 中 也 含 步 包 输 出 0 


作为 以 下 用 户 运行 (E) 


图 18-21 “新 建 作业 步骤 ?界面 中 的 “高 级 "选项 卡 
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© Es = 于， % 
站 二 股本 相生 
Ei 本 
EE 名 各国 etl 回 让 用 由 
类 型 中: SQL Server 事件 著 报 ~ 
事件 警报 定义 
数据 库 名 称 (8); teaching ~ 
将 根据 以 下 杀 件 名 发 区 报 : 
O 〇 庙号 四 1 
@ 严重 性 (): L001 - 杂 夺 系统 信息 > 
口 当 清 息 包含 以 下 内 容 9 租 发 警报 () 
消息 正文 0) 
服务 吕 
Lereomcse 
这 接 
L637CEYPESYNCSG\Adninistrat 
地 二 看 笑 接 屋 性 
就 半 


Cm ww | 
图 18-22 “新 建 警报 ”界面 中 的 “常规 ”选项 卡 


@ 输入 操作 员 的 “电子 邮件 名 称 ” 和 “Net send 地 址 ”及 工作 时 间 等 。 
@ 选择 “通知 ?选项 卡 ,选择 警报 及 通知 方式 ,如 图 18-23 所 示 。 


号 和 ”四 


按 以 下 方式 二 看 发 送 绽 此 用 户 的 通知 
@¥ 报 (E) 

作业 0 
警报 列表 (L) 
警报 名 称 电子 岂 件 “ 导 旦 程序 “Net send 
ertl 
testAlertl 
对 等 -中 柱 到 坟 报 
复制 : 代理 也 功 

代理 兴 败 

代理 重 斌 

代理 自 定义 关闭 

订阅 服务 器 未 通过 雪 据 夫 证 
订阅 服务 器 已 通过 娄 据 验证 
服务 器 验证 失败 后 重新 初 化 了 订阅 
L53TCEYPE9YWCSG 已 出 叭 过 Mt 有 隐 9 订阅 
订 网 过 期 傅 值 szpiration) 
事务 路 制 过 后 ( 国 值 : 1atency) 
车 直入 要 要 人 通过 LA 连接 进行 慢 这 合并 ( 裔 值 : 
通过 LA 连接 进行 长 时 间 合 并 ( 国 值 
着 过 拔 号 连 按 进行 恨 训 合并 (二 值 -we 
通过 按 号 连接 进行 时间 会 并 (信人 


连接 
L637CEYPESYNCSGWAdnini strat 


oooooo 图 oooooooes 
口 口 口 口 口 口 口 口 口 口 口 口 口 口 口 口 口 
口 口 口 口 口 口 口 口 口 口 口 口 口 口 口 回 
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@ 单 击 * 确 定 ? 按 钮 即 可 为 操作 员 user 分 配 警报 。 

(5) 创建 维护 计划 向 导 。 

g@ 在 “对 象 资源 管理 器 ”中 展开 SQL Server 实例 的 “管理 ” 子 目 录 , 然 后 右 击 “维护 计 
划 ” 文 件 夹 并 在 弹出 的 快捷 菜单 中 选择 “维护 计划 向 导 ” 命 令 , 在 起 始 页 面 中 单 击 “下 一 步 ” 
按钮 。 

@ 在 “名 称 ” 文 本 框 中 输入 维护 计划 的 名 字 。 在 本 例 中 使 用 “数据 库 teaching 备份 ” 作 
为 维护 计划 名 称 , 单 击 “ 下 一 步 ” 按 钮 。 选 择 “ 备 份 数据 库 ( 差 异 )”, 单 击 “ 下 一 步 ” 按 钮 两 次 。 

@ 在 “数据 库 ” 下 拉 列 表 框 中 选择 teaching 数据 库 , 单 击 “ 确 定 ” 按 钮 。 

@ 在 “目标 ”选项 卡 中 选择 “为 每 个 数据 库 创 建 备份 文件 ”选项 ,选中 “为 每 个 数据 库 创 
建 子 目 录 ” 复 选 框 ,并 指定 存储 备份 的 文件 夹 路 径 , 如 “D:\sqlprogram”, 单 击 “ 下 一 步 ” 按 钮 。 

@) 单 击 “ 更 改 ” 按 钮 以 创建 计划 。 进 入 “创建 作业 计划 ”界面 ,创建 backteaching 计划 。 
完成 之 后 单 击 “ 确 定 ” 按 钮 , 单 击 “ 下 一 步 ” 按 钮 。 

@ 在 随后 显示 的 页 面 中 可 以 定义 是 将 报告 写 入 文本 文件 还 是 以 电子 邮件 形式 发 送 报 
告 , 根 据 自己 的 情况 选择 。 然 后 单 击 “ 下 一 步 ?按钮 ,如 图 18-24 所 示 。 

面 维护 计划 向 导 


完成 旨意 agqgyam, 二 “守成” 


单 击 “ 完 成 ”以 执行 下 列 操作 : 


et 


已 选择 多 个 计划 
扣 . 定 X“ 备 份 数据 库 ( 差 导 ) ”任务 
| “备份 数据 库 所 在 的 位 置 
数据 库 : teaching 
型 ， 差 异 


追加 现 有 

目标 ;磁盘 
-备份 压缩 (nafaalt) 
| 运行 SQL S 代理 作业 : 在 每 周 星期 日 的 0:00:00 执行 。 将 从 2018/3/1 开始 使 用 计划 。 
日 所 计 千 法 页 


将 在 文件 夹 5 :i Files\Microsoft SQL S$ "WISSQL13. NSSQLSERYERWMSSQL\Log 中 生成 报 浊 
将 报告 发 送 到 ; % 


图 18-24 ”完成 维护 计划 向 导 
@ 单 击 “ 完 成 ”按钮 ,进入 完成 进度 窗口 ,进度 完成 后 单 击 “ 关 闭 ” 按 钮 。 
维护 计划 可 以 通过 SQL Server Management Studio 进行 更 改 。 展 开 “ 对 象 资源 管理 
器 ”一 “管理 ”>“ 维 护 计 划 ”, 然 后 右 击 需要 更 改 的 维护 计划 ,在 弹出 的 快捷 菜单 中 可 以 选择 
“查看 历史 记录 ”修改 “执行 ”等 命令 。 
若 单 击 “ 修 改 " 命 令 , 可 进行 手动 创建 维护 计划 的 过 程 。 若 单 击 “ 执 行 ”命令 ,可 以 进行 数 
据 库 备份 ,并 在 指定 路 径 生成 文档 报告 。 
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4. 实验 报告 总 结 

(1) 实现 系统 自动 化 管理 的 目的 。 

(2) SQL Server 代理 与 作业 、 警 报 和 操作 员 的 关系 。 
(3) 维护 计划 的 作用 。 


实验 15 复制 与 性 能 监视 


1. 实验 目的 

(1) 掌握 有 关 复 制 的 基本 操作 。 

(2) 掌握 创建 发 布 和 订阅 的 步骤 。 

(3) 熟悉 性 能 监视 器 的 基本 操作 。 

(4) 了 解 跟踪 的 创建 步骤 和 用 途 。 

2. 实验 预习 与 准备 

预习 主教 材 第 14 章 和 本 书 第 14 章 。 

(1) 复制 的 概念 分类、 创建 和 管理 。 

(2) 创建 发 布 和 订阅 的 步骤 。 

(3) 系统 性 能 监视 器 的 使 用 方法 。 

3. 实验 内 容 及 步 又 

(1) 创建 发 布 : 设 定 创建 发 布 的 数据 库 为 teaching。 

@ 在 Microsoft SQL Server Management Studio 中 连接 到 发 布 服务 器 ,在 “对 象 资源 管 
理 器 "中 展开 “复制 "文件 夹 , 右 击 “ 本 地 发 布 "文件 夹 。 

@ 在 弹出 的 快捷 菜单 中 选择 “新 建 发 布 " 命 令 , 弹 出 “新 建 发 布 向 导 ” 界 面 , 单 击 “ 下 一 
步 "按钮 ,然后 选择 发 布 数据 库 teaching, 单 击 “ 下 一 步 " 按 钮 。 

@ 选择 发 布 类 型 为 “事务 性 发 布 ”", 也 可 以 选择 能 够 较 好 的 支持 应 用 程序 要 求 的 其 他 发 
布 类 型 ,如 图 18-25 所 示 。 

让 新 发 布 内 导 


发 大 各 airkeslyoah 有 全 Fo 


发 布 类 型 (P) 


务 发 布 - 
订阅 服务 器 收 到 已 发 布 堵 据 的 初 杷 快照 后 ， 发 布 服务 器 将 事 务 流 式 传输 到 订阅 服务 器 。 


布 - 
发 布 支持 多 主 夏 制 。 发 布 服务 器 将 事 务 流 式 传输 到 拓扑 中 的 所 有 对 等 方 。 所 有 对 等 节点 可 以 读 到 和 写 入 
， 且 所 有 更 改 振 传 播 到 拓扑 中 的 所 有 节点 


已 发 布 雪 据 的 初始 快照 后 ， 发 布 服务 器 和 订阅 服务 器 可 以 抽 立 更 新 已 发 布 数 据 。 更 约会 定 
并 了 ierereft SQL Server Coapact Zaitien 只 能 订阅 合并 发 布 。 L 


履 助 0 ‘sm | rs"m, | 国 | 。， a 六 


图 18-25 选择 发 布 类 型 


外 单 击 * 下 一 步 "按钮 ,选择 要 发 布 的 对 象 ,如 选择 “ 表 ? 等 。 在 “筛选 表 行 ?界面 中 可 以 
单 击 “ 添 加 ”按钮 ,根据 需要 进行 表 中 数据 行 的 选择 ,如 图 18-26 所 示 , 可 以 通过 选择 表 中 的 
列 进 行 筛选 。 本 例 选 择 所 有 行 , 可 以 单 击 “ 取 消 ?按钮 返回 。 

@@ 单 击 “ 下 一 步 ?按钮 ,配置 “快照 代理 ”。 用 户 可 以 设置 代理 的 安全 性 。 在 创建 复制 的 
过 程 中 ,向 导 会 建立 一 系列 的 SQL Server 代理 作业 ,以 帮助 完成 复制 的 实现 与 维护 工作 。 
可 以 单 击 “ 安 全 设置 ”, 在 弹出 的 “快照 代理 安全 性 ”界面 中 指定 SQL Server 代理 账户 。 设 置 
完成 后 单 击 “ 确 定 ” 按 钮 ,返回 “代理 安全 性 ”界面 。 

让 添加 入 渤 吕 


1， 选择 要 般 选 的 表 (S)。 
student (dbo) 


。 完 戚 请 选 洒 司 以 标识 订阅 服务 器 所 要 接收 的 夫 行 。 示 全 光 司 


筛选 语句 (F): 
[SELECT <published_columns> FROM [dbo] [student] WHERE 


图 18-26 ”添加 筛选 器 


@ 设置 “向 导 操 作 ” 界 面 .本 例 选择 “创建 发 布 " 及 “生成 包含 创建 发 布 步骤 的 文本 文件 ” 
两 项 , 单 击 “下 一 步 ?按钮 。 设 置 “ 脚 本 文件 属性 ”, 单 击 * 下 一 步 ?按钮 。 

@ 在 “完成 该 向 导 ” 界 面 中 输入 发 布 名 称 fabu001。 通 过 提示 信息 对 前 面 的 选择 进行 回 
顾 , 确 认 后 单 击 “ 完 成 ”按钮 ,发 布 开始 创建 。 系 统 显 示 “ 正 在 创建 发 布 ”的 信息 ,全 部 显示 成 
功 后 单 击 “ 关 闭 ” 按 钮 ,完成 创建 发 布 。 在 “对 象 资源 管理 器 "中 可 以 查看 新 建 的 发 布 。 

(2) 创建 订阅 。 

@ 在 Microsoft SQL Server Management Studio 中 连接 到 订阅 服务 器 (命名 实例 ) , 展 
开 “ 复 制 ” 子 目录 。 右 击 “ 本 地 订阅 ”, 在 弹出 的 快捷 菜单 中 选择 “新 建 订阅 "命令 ,弹出 “新 建 
订阅 向 导 ” 界 面 , 单 击 “ 下 一 步 ” 按 钮 。 

@ 在 “新 建 订阅 向 导 ” 界 面 的 “发 布 ” 选 项 卡 中 的 “发 布 服务 器 ”下 拉 列 表 框 中 选择 “< 查 
找 SQL Server 发 布 服务 器 >” 选 项 。 在 “连接 到 服务 器 ”界面 中 连接 到 发 布 服务 器 (默认 实 
例 ) ,然后 在 “发 布 ”选项 卡 中 选择 一 个 发 布 ,如 图 18-27 所 示 , 单 击 “ 下 一 步 ” 按 钮 。 

@ 在 “分 发 代理 位 置 " 界 面 中 选择 分 发 代理 位 置 ,如 “在 其 订阅 服务 器 上 运行 每 个 代理 
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和 图 新 结 订 阅 向 导 


发 布 a 
请 选择 要 为 其 创建 一 个 或 多 个 订阅 的 发 布 。 


testO! 
上 - 昨 testol- 由 


18-27 选择 发 布 项 目 


(请 求 订阅 )" 项 , 单 击 “ 下 一 步 ” 按 钮 。 在 “订阅 服务 器 ”对 话 框 中 选择 “新 建 数据 库 ”, 创 建 目 
标 数据 库 teaching, 如 图 18-28 所 示 , 单 击 “ 下 一 步 ” 按 钮 。 


名 J 同和 ee 
订 癌 限 务 各 号 本 
请 选择 一 个 或 多 个 订阅 服务 器 并 指定 每 个 订阅 数据 库 。 Nn 
订阅 服务 器 和 订阅 数据 库 (S) 
订阅 服务 器 全 iD 用 
回 LS37cEYPE9YYcsG reachine | 


18-28 选择 订阅 数据 库 


@ 在 “分 发 代理 安全 性 ”界面 中 设置 “分 发 代理 安全 性 选项 "后 , 单 击 “ 确 定 ” 按 钮 返回 。 
单 击 “ 下 一 步 " 按 钮 ,进入 “同步 计划 ”界面 中 指定 每 个 订阅 的 代理 的 同步 计划 ,如 “连续 运 
行 ”。 单 击 * 下 一 步 ?按钮 ,进入 “初始 化 订阅 ”界面 ,用 户 可 以 指定 “首先 同步 ”的 初始 化 选择 。 

@ 在 “向 导 操 作 ” 界 面 中 ,本 例 选择 默认 项 “在 向 导 结束 时 一 创建 订阅 ”。 

@ 在 “完成 该 向 导 ” 界 面 中 通过 提示 信息 对 前 面 的 选择 进行 回顾 ,确认 后 单 击 “完成 ” 按 
钮 ,订阅 才 开 始 创 建 。 

@ 创建 订阅 后 ,用 户 可 以 在 “资源 管理 器 ”中 查看 发 布 和 订阅 。 此 时 用 户 可 以 在 发 布 数 
据 库 中 向 数据 库 的 表 中 插入 数据 ,在 订阅 数据 库 的 表 中 看 到 同步 的 结果 。 

(3) 验证 复制 。 通 过 向 发 布 数据 库 teaching 的 course 表 中 插入 数据 ,观察 订阅 服务 器 
中 数据 库 teaching 的 course 表 的 数据 是 否 同步 来 验证 。 


@ 展开 发 布 数据 库 teaching 的 “ 表 ? 子 目录 , 右 击 course 表 , 在 弹出 的 快捷 菜单 中 选择 
“打开 表 ” 命 令 ,添加 一 条 记录 。 

@ 展开 订阅 数据 库 teaching 的 “ 表 ” 子 目录 , 右 击 course 表 , 在 弹出 的 快捷 菜单 中 选择 
“打开 表 ” 命 令 , 则 course 表 同 样 插入 了 记录 行 。 

@ 也 可 以 对 其 他 表 的 数据 进行 修改 验证 。 

(4) 性 能 监视 器 的 使 用 。 

QO@ 选择 “开始 ”>“ 运 行 "命令 ,在 “运行 "界面 中 输入 perfmon 命令 ,然后 单 击 “ 确 定 ” 按 
钮 即 可 启动 系统 监视 器 ,如 图 18-29 所 示 。 


因 性 能 监视 器 

加 文件 ()” 授 作 (A) 过 看 V) 窗口 W) 帮助 (H) 
和 中 | 直 郑 | 国 响 | 目 回 
© tt 辆 可 加 "| 呈 XZY| 宣 自 国生 | 中 是 | 


EE 8:15:30 8:15:40 8:14:10 8:14:20 8:14:30 8:14:40 8:14:50 8:15:00 B:15:15 


最 新 | 0.000 平均 | 53.551 最 小 0.000 

最 大 | 1.815.668 持续 时 间 140 

显示 颜色 比例 计数 器 实例 父系 2 总 
ea 10 % Processor Time Total processk 
ea 10 Local Usage luid Ox00.. GPU Loc 

[a 10 % Processor Time 2 Processt v 
< > 


18-29 系统 性 能 监视 器 


@ 右 击 界面 ,在 弹出 的 如 图 18-30 所 示 “ 添 加 计数 器 "界面 中 可 以 添加 系统 监视 器 启动 
后 监视 的 SQL Server 对 象 和 计数 器 。 

@@ 单 击 “X ”按钮 可 以 删除 图 表 中 的 选中 对 象 。 

@ 可 以 配置 系统 监视 器 显示 任何 SQL Server 计数 器 中 的 统计 信息 。 另 外 ,可 以 为 任 
何 SQL Server 计数 器 设置 一 个 阔 值 , 当 计数 器 超过 阔 值 时 生成 一 个 警报 。 

@ 可 以 定期 监视 SQL Server 实例 确定 CPU 使 用 率 是 否 在 正常 范围 内 。 检 查处 理 器 
使 用 率 时 , 若 使 用 率 为 100% 左 右 , 表 示 在 处 理 大 量 的 客户 端 请 求 , 可 能 表示 进程 正在 排队 ， 
等 待 处 理 器 时 间 ,并 因而 导致 出 现 瓶 颈 。 可 通过 增加 速度 更 快 的 处 理 器 来 解决 这 一 问题 。 

(5) 参考 主教 材 第 14 章 的 14. 4.4 节 , 了 解 跟踪 的 创建 步骤 和 用 途 。 

4. 实验 报告 总 结 


(1) SQL Server 采用 的 客户 端 / 服 务 器 模型 及 客户 端 和 服务 器 端 组 件 的 功能 。 第 
(2) SQL Server Management Studio 集成 环境 的 构成 和 基本 操作 。 18 
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Security per-process Statistics 
Security System-Wide Statistics 
Server 
Blocking Requests Rejected 
Bytes Received/sec 
Bytes Total/sec 
Bytes Transmitted/sec 


光 


四 


选 定 对 龟 的 实 人 (1): 


添加 计数 露 
可 用 计数 器 添加 的 计数 器 (C) 
算 机 选择 计数 器 (M): 
从 计 和 计数 器 实例 。 计算 机 
< 本 地 计算 机 > ~| | WS(e).. Memory 
Search Gatherer Projects | Server 
Search Indexer Bytes Received/sec 


18-30 ”添加 计数 器 


(3) SQL Server 2016 服务 器 的 配置 。 


实验 16 综合 练习 
1. 实验 目的 


(1) 图 书 管理 数据 库 的 创建 和 管理 。 
(2) 常用 数据 库 对 象 的 基本 操作 。 
(3) 图 书 数据 库 的 安全 管理 备份 和 还 原 。 


2. 实验 预习 与 准备 
(1) 数据 库 开发 的 一 般 过 程 。 


(2) SQL Server 数据 库 对 象 : 表 、 视 图 .索引 、\ 存 储 过 程 、 触 发 器 的 创建 和 管理 。 
(3) 数据 库 的 安全 管理 : 登录 ,账户 .角色 和 权限 管理 。 


(4) 数据 库 的 备份 和 还 原 。 
3. 实验 内 容 及 步 又 


需求 分 析 : 图 书馆 管理 系统 主要 用 于 对 图 书馆 日 常 工作 的 管理 ,主要 任务 是 利用 图 书 
管理 系统 对 读者 、 图 书 等 各 种 信息 进行 日 常 管理 ,如 查询 修改、 增加、 删除 .图书 借阅 和 归还 
的 管理 等 。 要 完成 图 书 管理 系统 的 日 常 管理 功能 ,其 数据 库 的 设计 可 以 从 图 书信 息 、 用 户 信 
息 、 借 阅 信息 以 及 管理 员 信息 等 几 个 方面 考虑 ,并 将 这 些 信 息 转化 为 图 书 管理 系统 所 需要 的 


数据 库 Library 的 数据 表 ,部 分 表 结构 描述 如 下 : 
@ 图 书信 息 表 Bookinfo( 图 书 ID, 图 书 ISBN, 书 名 ,图 书 类 别 , 作 者 ,出 版 社 ,出 版 日 


期 ,价格 ,入 馆 日 期 ,数量 ,借阅 状态 )。 

@ 读者 信息 表 Readerinfo( 读 者 ID, 读 者 名 ,密码 ,读者 类 别 ,电话 ,注册 日 期 ,所 属 部 
门 , 最 多 借阅 数 , 最 多 借阅 天 数 , 是 否 借 阅 ,已 借 书籍 数量 ,超期 数 ,读者 学 历 )。 

@@ 借阅 信息 表 Borrowinfo( 借 阅 ID, 图 书 ID ,读者 ID, 借 阅 日 期 , 借 书 职员 ID, 归 还 日 


期 ,还 书 职员 ID, 图 书 状态 )。 
@ 职员 信息 表 Clerkinfo( 职 员 ID ,密码 ,姓名 ,身份 证 号 ,身份 类 别 ) 。 
下 面 以 图 书 管理 数据 库 Library 为 例 ,进行 SQL Server 2016 数据 库 软 件 的 常见 操作 。 


(1) 图 书 管理 数据 库 Library 的 基本 操作 。 


-- 数 据 库 Library 的 修改 
CREATE DATABASE Library 
ON 
(NAME = 'D:\DATA\Library_DATA', 
FILENAME = 'D:\DATA\Library. MDF', 
SIZE=5, 
MAXSIZE = UNLIMITED, 
FILEGROWTH = 3 
) 
LOG ON 
(NAME = 'D:\DATA\Library_LOG', 
FILENAME = 'D:\DATA\Library. LDF’, 
SIZE=2, 
MAXSIZE = 10, 
FILEGROWTH = 10 % 
) 
GO 
=- 数据库 Library 的 修改 
ALTER DATABASE Library 
ADD FILE 
(NAME = Library_DATAl, 
FILENAME = 'D:\DATA\Library_DATAl. ndf', 
SIZE = 6MB, 
MAXSIZE = 100MB, 
FILEGROWTH = 6MB) 
一 -添加 数据 文件 
ALTER DATABASE Library 
MODIFY FILE 
(NAME = Library_DATA1, SIZE = 25MB) 
一 -数据 文件 删除 
ALTER DATABASE Library 
REMOVE FILE Library DATAl 
一 -分 离 数据 库 Library 
USE master 
GO 
EXEC master. dbo. sp_detach db @dbname = N'Library' 
GO 
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-- 附加 图 书 管理 系统 数据 库 

USE master 

GO 

CREATE DATABASE [Library] ON 

( FILENAME = N'D:\data\Library.MDF' ), 

( FILENAME = N'D:\data\Library.LDF') 
FOR ATTACH 

G0 


(2) 图 书 管理 数据 表 的 基本 操作 。 


-- 创建 表 Bookinfo 

create table dbo. Bookinfo 

( 
Book_ID nchar(8) not null, 
Book_ISBN nchar(20) null, 
Book_name nvarchar(50) null, 
Book_type nchar(30) null, 
Book_author nvarchar(30) null, 
Book_press nvarchar(50) null, 
Book_ pressdate date null, 
Book_price money null, 
Book_inputdate date null, 
Book quantity int null, 
Book_isborrow nvarchar(1) null, 
) 

GO 

=-- 创建 表 Clerkinfo 

create table dbo. Clerkinfo 

( 
Clerk_ID nchar(8) not null, 
Clerk_password nvarchar(20) null, 
Clerk_name nvarchar(30) null, 
Clerk_identitycard nchar(18) null, 
Clerk type nchar (30) nmull, 

) 

GO 

-- 创建 表 Readerinfo 

create table dbo. Readerinfo 

( 
Reader_ID nchar(8) not null, 
Reader_password nvarchar(20) null, 
Reader name nvarchar(30) null, 
Reader identitycard nchar(18) null, 
Reader type nchar(40) null, 
Reader telephone nchar(20) null, 
Reader registerdate datetime null, 
Reader department nchar(50) null, 
Reader maxborrownum int null, 
Reader_ maxborrowday int null, 
Reader isborrow nchar(1) null, 


Reader borrowednum int null, 
Reader overduenum int null, 


) 
GO 


-- 创建 表 Borrowinfo 


create table dbo.Borrowinfo 


( 


Borrow_ID int not null, 
Book_ID nchar(8) null, 
Reader_ID nchar(8) null, 
Borrow_date datetime null, 


Borrow_clerk_ID nchar(8) null, 


Return date datetime null, 


Return clerk_ID nchar(8) null, 
Book state nchar(8) null, 


) 
GO 


-一 修改 表 Readerinfo 
alter table Readerinfo 


add Reader_ knowledge nvarchar(30) 


G60 


一 修改 表 Bookinfo 
alter table Bookinfo 


alter column Book_isborrow bit 


60 


-修改 表 Clerkinfo 
alter table dbo.Clerkinfo 


drop column Clerk_identitycard 


GO 


一 创建 如 图 18 - 31 所 示 的 数据 库 关系 图 
其 中 包括 添加 表 , 设 置 各 表 的 主键 ,并 实现 主键 和 外 键 的 关联 操作 。 


Bookinfo 


时 Book!D 
Book ISBN 
Book name 
Book type 
Book_author 
Book press 
Book pressdate 
Book price 
Book inputdate 
Book quantity 
Book isborrow 


Clerkinfo 
8 ClerkID 
Clerk_password 
Clerk name 
Clerk type 


Borrowinfo 
BorrowID 

Book ID 
Reader ID 
Borrow date 
Borrow clerkID 
Return_date 
Return_clerk ID 
Book state 


18-31 创建 表 的 数据 库 关 系 图 


Readerinfo 


> 


Reader ID 
Reader password 
Reader name 
Reader identitycard 
Reader type 
Reader telephone 
Reader_ registerdate 
Reader department 
Reader_maxborrownum 
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一 添加 表 Bookinfo 的 数据 (/* 可 以 输入 多 行 数据 * /) 

insert into Bookinfo(Book_ID, Book_ ISBN, Book name, Book type, Book author, Book press, Book_ 
pressdate, Book price, Book inputdate , Book quantity, Book isborrow) 
VALUES( 70201008', '9787302111111', 数据 库 维 护 与 编程 ', "数据库 设计 '，' 李 宏文 '，' 清 华 大 学 出 版 社 
a a A ) 

GO 

一 修改 表 数 据 

update Bookinfo 

set Book price = Book price +10 

where Book_press = ' 科 学 出 版 社 ' 

GO 

一 删除 表 数 据 

delete from Bookinfo 

where Book_press = ' 科 学 出 版 社 ' 

GO 

-添加 check 约束 

ALTER TABLE Bookinfo 

ADD CONSTRAINT YS_pressdate 

CHECK( Book_pressdate >'1950 — 1 — 1' AND Book_pressdate < GETDRTE() ) 

-- 添加 外 键 约束 

ALTER TABLE Borrowinfo 

RDD CONSTRAINT FK_Borrowinfo Readerinfo 

FOREIGN KEY (Reader_ID) 

REFERENCES Readerinfo(Reader_ID) 


(3) 图 书 管理 数据 的 复杂 查询 。 


一 利用 1ike 实现 模糊 查询 (查询 姓氏 介 于 胡 到 赵 , 或 者 林 到 章 图 书 作者 名 ) 
SELECT Book_name, Book_author, Book_press 

FROM Bookinfo 

WHERE Book_author LIKE '[ 胡 一 赵 , 林 一 章 ]%' 

-将 查询 结果 存 到 临时 变量 

DECLARE @bookname nvarchar(50) 

DECLARE @bookauthor nvarchar(30) 

DECLARE (@bookprice money 

SELECT (@bookname = Book_name, @bookauthor = Book_author, @bookprice = Book_price 
FROM Bookinfo 

WHERE Book_ID = '80201025 

SELECT (@bookname, @bookauthor, @bookprice 

一 利用 with Rollup 选项 汇总 检索 图 书 数据 表 信 息 

SELECT Book_press, COUNT( Book_name) 图 书 册 数 , AVG(Book_price) 图 书 平均 价格 
FROM Bookinfo 

GROUP BY Book_press 

With rollup 

HAVING AVG(Book_price)> 45 

-- 利用 多 表 连 接 检索 图 书 管理 系统 数据 表 信 息 (内 连接 ) 

SELECT R. Reader_name, Book_name, Book_press, Book_price 

FROM Bookinfo B INNER JOIN Borrowinfo BT ON BT. Book_ID = B. Book_ID 
INNER JOIN Readerinfo R ON BT. Reader_ ID= R. Reader_ID 

ORDER BY “ BT. Reader_ID DESC 

-- 利用 多 表 连 接 检索 图 书 管理 系统 数据 表 信 息 ( 左 外 连接 ) 


SELECT Readerinfo.Reader name,Book name, Borrowinfo.Borrow Date,Book price 
FROM Bookinfo LEFT OUTER JOIN Borrowinfo ON 
Borrowinfo. Book_ID = Bookinfo. Book_ID LEFT OUTER JOIN Readerinfo 
ON Borrowinfo.Reader ID= Readerinfo.Reader ID 
ORDER BY Borrowinfo. Reader_ID DESC 
-利用 多 表 连 接 检 索 图 书 管理 系统 数据 表 信 息 ( 右 外 连接 ) 
SELECT Readerinfo. Reader name, Readerinfo. Reader type, Borrowinfo. Borrow_ Date, Borrowinfo. 
Return Date 
FROM Borrowinfo RIGHT OUTER JOIN Readerinfo ON 
Readerinfo. Reader_ ID= Borrowinfo. Reader ID 
ORDER BY Readerinfo. Reader ID 
-- 利用 子 查询 检索 出 版 社 图 书 的 平均 价格 
SELECT DISTINCT B1. Book_press, 平 均 价格 = (SELECT AVG(Book_price) 
FROM Bookinfo B2 
WHERE Bl1.Book press= B2.Book press) 
FROM Bookinfo Bl1 
ORDER BY Bl1.Book press 
-利用 子 查询 检索 读者 的 借阅 情况 
SELECT R.Reader name 
FROM Readerinfo R 
WHERE R. Reader_ID IN(SELECT B.Reader ID 
FROM BorrowinfoB WHERE B.Book State= '1') 
ORDER BY R.Reader_ID 


(4) 索引 和 视图 的 设计 及 应 用 。 


=- 建立 图 书信 息 表 的 索引 

CREATE INDEX INDEX_PRESSAUTHOR 

ON Bookinfo(Book_press, Book_author) 

-- 建立 读者 信息 表 的 唯一 索引 ,填充 因子 为 80 

CREATE UNIQUE NONCLUSTERED INDEX INDEX READERID 

ON Readerinfo(Reader ID) 

WITH PAD_INDEX, 

FILLFACTOR = 80 

-- 创建 并 查看 图 书信 息 表 Bookinfo 的 视图 

CREATE VIEW VIEW_BOOK 

RS 

SELECT Book_ID, Book ISBN, Book name, Book type, Book author, Book press, Book pressdate, Book 

_price 

FROM Bookinfo 

GO 

SELECT * FROM VIEW_BOOK 

一 -利用 视图 添加 数据 

insert into VIEW BOOK(Book_ID, Book_ISBN, Book name, Book type,Book author, 

Book_ press, Book_ pressdate, Book price) 

VALUES( '10032245', '9788836502343', 'C 程序 设计 教程 ', ' 程 序 语 言 ', ' 吴 华 琴 ', ' 科 学 出 版 社 '， 
2010-1=1'"735) 

SELECT * FROM Bookinfo WHERE Book ID= '10032245' 


-- 利用 视图 修改 数据 第 
UPDATE VIEW_BOOK SET Book pressdate= '2017 一 11 一 10' 18 
WHERE Book_ID = '10032245 章 


侨 验 北 时 与 实验 内 容 


SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 志 指 时 


SELECT * FROM Bookinfo WHERE Book _ID= '10032245' 
-- 利用 视图 删除 数据 

DELETE FROM VIEN_BOOK 

WHERE Book_ID= '10032245' 


(5) 存储 过 程 和 触发 器 的 设计 及 应 用 。 


-- 建立 并 执行 查看 图 书 数量 的 存储 过 程 
CREATE PROCEDURE sp_bkquantity 
RS 
BEGIN 
SELECT Book_ID, Book_name, Book_author, Book_press, Book_price, Book quantity 
FROM Bookinfo 
WHERE Book_quantity<5 
END 
Exec sp_bkquantity 
-- 建立 并 执行 查看 出 版 社 图 书信 息 的 存储 过 程 
IF EXISTS(SELECT NAME FROM SYSOBJECTS WHERE NAME = 'proc_bookpress' RND TYPE = 'P') 
DROP PROCEDURE proc_bkpress 
GO 
CREATE PROCEDURE proc_bookpress 
@PRESS NVARCHAR(50) = ' 清 华 大 学 出 版 社 ' 
RS 
SELECT Book_ID, Book_name, Book_type, Book_author, Book_press, Book_price 
FROM Bookinfo 
WHERE Book_press = @PRESS 
G0 
EXECUTE proc_bookpress ' 科 学 出 版 社 ' 
-- 创建 有 输出 参数 的 存储 过 程 
IF EXISTS(SELECT NAME FROM SYSOBJECTS 
WHERE NAME = 'p_readerdepart' AND TYPE = 'P') 
DROP PROCEDURE p_readerdepart 
GO 
CREATE PROCEDURE p_readerdepart 
@ReaderID NVARCHAR(8), 
@Readername NVARCHAR(30) OUTPUT, 
@Readerdepartment NVARCHAR(50) OUTPUT 
RS 
SELECT @Readername = Reader_name, @Readerdepartment = Reader department 
FROM Readerinfo 
WHERE Reader_ID = @ReaderID 
GO 
一 -执行 有 输出 参数 的 存储 过 程 
DECLARE @ReaderID NVARCHAR(8), @Readername NVARCHAR(30), 
@Readerdepartment NVARCHAR(50) 
EXEC p_readerdepart 'A1000137 ', @Readername OUTPUT, (@Readerdepartment OUTPUT 
SELECT @Readername, @Readerdepartment 
-- 创建 图 书 表 的 插入 触发 器 
if exists(select name from sysobjects 
Where name = 'tri borinsert'and type= 'tr') 
drop trigger tri borinsert 


go 

create trigger tri borinsert 

on Borrowinfo 

for insert 

as 

declare @BorrowDate datetime 

declare @Readerregisterdate datetime 


select @BorrowDate = Borrowinfo. Borrow_Date from Borrowinfo, inserted 


where Borrowinfo. Borrow_ID= inserted. Borrow_ID 


select @Readerregisterdate = Readerinfo. Reader registerdate 


from Readerinfo, Borrowinfo 
where Readerinfo. Reader_ID= Borrowinfo. Reader ID 
if @BorrowDate <@Readerregisterdate 


begin 

raiserror( ' 没 有 注册 登记 的 读者 不 能 借阅 图 书 ,请 删除 该 行 数据 ! ', 16, 10) 
end 
go 


-- 验证 触发 器 tri_borinsert 


insert into Borrowinfo 


(Borrow_ID, Book_ID, Reader_ID, Borrow_Date, Borrow_clerk_ID, Return Date, Return clerk_ID, Book 
_State)values(100724017, '90201027', 'A1000738', '2017 - 11 ~ 10', 'C0003', null,null, '1') 


Select * from Borrowinfo where Borrow_ID = 100724017 
-- 创建 读者 表 的 更 新 触发 器 
if exists(select name from sysobjects 
where name = 'tri_readerupdate' and type = 'tr') 
drop trigger tri_readerupdate 
go 
create trigger tri_readerupdate 
on Readerinfo 
for update 
as 
if update(Reader telephone) 
begin 
select inserted. Reader name, inserted. Reader telephone 
as new_Readertelephone, 
deleted. Reader_telephone as old_Readertelephone 
from inserted, deleted 
where inserted. Reader_ID= deleted. Reader_ID 
end 
go 
-- 创建 图 书 表 的 删除 触发 器 
if exists (select name from sysobjects 
Where name = 'tri_Bookdeleted' and type= 'tr') 
drop trigger tri_Bookdeleted 
go 
Create trigger tri Bookdeleted 
on Bookinfo 
for delete 
as 
select sum(deleted. Book_quantity) as ' 被 删除 图 书 总 本 数 '， 
sum(deleted. Book_price) as ' 被 删除 图 书 总 金额 ' 
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from deleted 

go 

delete Bookinfo where left(Book ID,1) = 'A' 
-- 查 看 图 书 管理 系统 的 触发 器 

sp_help tri_Bookdeleted 

sp_helptext tri_readerupdate 

sp_depends Borrowinfo 

一 -禁用 或 启用 图 书 管理 系统 的 触发 器 
DISABLE TRIGGER tri Bookdeleted ON Bookinfo 
ENABLE TRIGGER tri Bookdeleted ON Bookinfo 


(6) 自 定义 函数 和 游标 的 应 用 。 


=-- 利用 自 定义 函数 检测 图 书 数量 
IF EXISTS(SELECT name FROM sysobjects 
WHERE name = 'bookquantity lowhigh ' RND xtype = 'FN') 
DROP FUNCTION books_lowhigh 
GO 
CREATE FUNCTION books_lowhigh (@quantity int) 
RETURNS nvarchar(30) 
BEGIN 
DECLARE (@ loworhigh nvarchar(30) 
IF @quantity> 5 
SET @loworhigh = ' 库 存 充 足 ' ELSE SET @]loworhigh = ' 需 要 购置 ' 
RETURN @ loworhigh 
END 
一 自 定义 函数 的 调用 方法 
SELECT TOP 5 Book_name, Book_quantity, DBO. books_lowhigh(Book_quantity) 
from Bookinfo 
-- 利用 游标 检查 超过 50 元 的 图 书 
DECLARE @VarCur Cursor 
DECLARE cur_book50 CURSOR 
FOR 
SELECT Book_ name, Book_ price 
FROM Bookinfo 
WHERE Book_price> 50 
OPEN cur_book50 
SET @VarCur = cur_book50 
FETCH NEXT FROM @VarCur 
WHILE @(@FETCH STATUS = 0 
BEGIN 
FETCH NEXT FROM @VarCur 
END 
CLOSE @VarCur 
DEALLOCATE (@VarCur 
一 -利用 游标 查看 读者 为 教师 的 部 门 信息 
DECLARE @readname NVARCHAR(30), @readdepartment NCHAR(50) 
DECLARE cur_reader CURSOR 
FOR 
SELECT Reader_ name, Reader department 
FROM Readerinfo 


WHERE Reader type= ' 教 师 ' 
OPEN cur_reader 
FETCH NEXT FROM cur reader 
INTO @readname, @readdepartment 
PRINT 教师 的 姓名 和 所 在 系 部 : ， 
PRINT ' 姓 名 : “+ 系 部 : 
WHILE @@FETCH STATUS =0 
BEGIN 
PRINT @readname+ ' "+ @readdepartment 
FETCH NEXT FROM cur reader 
INTO @readname, @readdepartment 
END 
CLOSE cur_reader 
DEALLOCATE cur_reader 


(7) 事务 和 锁 的 设计 及 应 用 。 


-- 应 用 事务 检测 图 书 的 借阅 状况 
IF EXISTS(SELECT name FROM sysobjects 
WHERE name = 'proc_returnaffairbook' RND type = 'P') 
DROP PROCEDURE proc_bkreturn 
GO 
CREATE PROCEDURE proc_bkreturn 
@bookid nvarchar(8), 
@readerid nvarchar(8), 
@clerkid nvarchar(8) 
RS 
DECLARE @Borrowed id int 
SELECT (@Borrowed_id = Borrow_ID FROM Borrowinfo 
WHERE Reader_ID = @readerid AND Book_ID = @bookid 
IF @@ROWCOUNT >0 
BEGIN 
BEGIN TRAN 
Update Borrowinfo SET Return clerk ID= @clerkid, 
Return_Date = getdate( ), Book_State = ' 归 还 ' 
WHERE Borrow_ID= 140305001 
UPDATE Bookinfo SET Book_isborrow= '1',Book quantity = Book quantity+1 
WHERE Book_ID= '10301012" 
Update Readerinfo SET Reader isborrow = '1', 
Reader_ borrowednum = Reader borrowednum— 1 
WHERE Reader_ID = @readerid 
IF @@ERROR> 0 


ROLLBACK TRAN 
ELSE 
COMMIT TRAN 
END 
ELSE 
PRINT ' 该 读者 没有 借阅 此 书 ' 
a 第 
-- 多 次 执行 存储 过 程 , 查 看 读者 的 借阅 情况 18 
EXEC proc_bkreturn @bookid = '80201025', @readerid= 'A1000035', 章 
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@clerkid= 'C0001' 

EXEC proc_bkreturn @bookid = '80201025', @readerid = 'A1000337', 
@clerkid = 'C0007' 

一 - 利用 锁 管理 读者 信息 

BEGIN TRANSACTION 

SELECT * FROM Readerinfo 

EXEC SP_LOCK 

INSERT INTO Readerinfo VALUES( '10010209', '123123', ' 王 法 务 '，'260101198506126785', ' 学 生 '， 
'19089769999', '2017 -03 -27', ' 软 件 工程 系 ',8, 30, '1', 0,0, NULL) 
SELECT * FROM Readerinfo 

EXEC SP_LOCK 

COMMIT TRANSACTION 


(8) 图 书 管理 数据 库 的 安全 管理 。 


-- 查 看 系统 登录 名 sa 的 信息 

sp_helplogins sa 

-- 创建 登录 名 

USE Library 

CREATE LOGIN lib log001 WITH PRSSWORD = '111111' 
一 利用 系统 过 程 sp_addlogin 向 Library 数据 库 创建 三 个 新 登录 
USE master 

G0 

EXEC sp_addlogin 'rose_lib', 'abcabc', 'Library’ 
GO 

EXEC sp_addlogin "hanry_lib'，'abcabc'，'Library ' 
G0 

EXEC sp_addlogin 'pool_lib', 'abcabc', 'Library ' 
GO 

一 -修改 登录 名 hanry_lib 的 密码 

sp_password ‘'abcabc', '123123', 'hanry_lib' 

-- 创建 Library 数据 库 的 用 户 


CREATE USER user rose FOR LOGIN rose lib 

一 修改 Library 数据 库 的 用 户 名 

ALTER USER user_rose WITH NAME = userl 

=-- 删除 Library 数据 库 的 用 户 名 

IE EXISTS(SELECT x* FROM sys. database_principals WHERE name = N'user1') 
DROP USER userl 


-- 创建 和 删除 Library 数据 库 的 角色 

EXEC sp_addrole 'lib role01' 

GO 

EXEC sp_droprole 'lib role01 

GO 

=-- 添加 和 删除 Library 数据 库 的 角色 成 员 
EXEC sp_addsrvrolemember 'user1l',，'Ssecurityadmin' 
GO 

EXEC sp_dropsrvrolemember 'userl',，'sysadmin' 
GO 

一 -设置 Bookinfo 表 上 的 对 象 权 限 


GRANT INSERT, SELECT ON dbo. Bookinfo TO userl WITH GRANT OPTION 


GO 
GRANT DELETE ON dbo. Bookinfo TO userl 


GO 

DENY ALTER ON dbo. Bookinfo TO userl 

GO 

一 -设置 Bookinfo 表 列 上 的 对 象 权 限 

DENY UPDATE ON dbo. Bookinfo(Book_ID) TO userl 

GO 

GRANT UPDATE ON dbo. Bookinfo(Book name) TO userl RS dbo 
GO 

DENY UPDATE ON dbo. Bookinfo(Book press) TO userl 

GO 


GRANT UPDATE ON dbo. Bookinfo(Book_author) TO userl 
WITH GRANT OPTION RS dbo 

GO 

-- 查 看 对 象 Bookinfo 权限 

EXECUTE sp_helprotect 'Bookinfo' 

GO 


(9) 数据 库 的 备份 及 还 原 。 


一 -创建 备份 设备 Lib 
USE master 
GO 
EXEC master. dbo. sp_addumpdevice 
@devtype = N'disk', 
@logicalname = N'lib', 
@physicalname = N'D:\data\lib' 
GO 
一 -完整 备份 数据 库 Library 
BACKUP DATABASE Library TO lib 
WITH INIT，NAME = N'Library 完整 数据 库 备份 '， 
DESCRIPTION = 'Library 完整 备份 放置 在 lib 备份 设备 中 ' 
GO 
-- 差异 备份 数据 库 Library 
BACKUP DATABASE Library TO 1ib 
WITH DIFFERENTIAL，NOINIT, NAME = 'Library 差异 备份 '， 
DESCRIPTION = N'Library 差异 备份 放置 在 1ib 备份 设备 中 
G0 
-- 数 据 库 Library 的 事务 日 志 备份 
BACKUP LOG Library TO lib 
WITH DESCRIPTION = N'Library 事 务 日 志 备份 放置 在 1ib 备份 设备 中 '， 
EXPIREDATE = N'02/11/2018 00:00:00', 
NAME = N'Library -事务 日 志 备 份 ' 
GO 
一 Library 文件 组 备份 
BACKUP DATABASE Library FILEGROUP = N'PRIMARY'TO [1ib] 
WITH DESCRIPTION = N'Library 文件 组 备份 放置 在 1ib 备份 设备 中 


NAME = N'Library- 数据 文件 组 备份 ' 第 
18 
=-- 利用 完整 备份 还 原 图 书 管理 Library 数据 库 章 
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USE master 
BACKUP LOG [Library] TO 
DISK = N'C:\Program Files\Microsoft SQL Server\MSSQL13. MSSQLSERVER \MSSQL\Backup\Library_ 
LogBackup 2018 - 03 - 11_16 - 37 - 12. bak' WITH NOFORMAT, NOINIT, NAME = N'Library_ 
LogBackup 2018 -03-11 16-37-12', 
NOSKIP, NOREWIND, NOUNLOAD, NORECOVERY, STRTS = 5 
RESTORE DATABASE Library FROM lib 
WITH FILE = 1, REPLACE 
GO 
-- 利用 完整 + 差异 + 日 志 备份 还 原 图 书 管理 Library 数据 库 
USE master 
BACKUP LOG Library TO DISK = N'C:\Program Files\Microsoft SQL Server\ MSSQL13.MSSQLSERVER\ 
MSSQL\Backup\Library LogBackup 2018 -03—11 16— 40 - 38.bak'WNITH NOFORMAT, NOINIT, 
NAME = N'Library LogBackup 2018-03-11 16-40-38', STATS = 5 
RESTORE DATABASE Library FROM lib 
WITH FILE = 1, REPLACE, STATS = 5 
RESTORE DATABASE Library FROM lib 
WITH FILE = 2, STATS = 5 
RESTORE LOG Library FROM 1ib 


WITH FILE = 3, STATS = 5 
GO 
=-- 利用 完整 + 日 志 备 份 还 原 图 书 管理 Library 数据 库 
USE master 


BACKUP LOG Library TO DISK = N'C:\Program Files\Microsoft SQL Server \MSSQL13.MSSQLSERVER\ 
MSSQL\Backup\Library LogBackup 2018 -03—11 16— 45 - 42. bak' WITH NOFORMAT, NOINIT, 
NAME = N'Library LogBackup 2018-03—11 16-45- 42', NOSKIP, NOREWIND, NOUNLOAD, 
NORECOVERY , STATS = 5 

RESTORE DATABASE Library FROM lib 
WITH FILE = 1, REPLACE, STATS = 5 

RESTORE LOG Library FROM lib 
WITH FILE = 3, STATS = 5 

G0 

=-- 利用 文件 组 备份 还 原 图 书 管理 Library 数据 库 的 数据 文件 

RESTORE DATABASE Library FILE = N'D:\DATA\Library_DATA' 

FROM DISK = N'D:N\dataNlib' 

WITH FILE = 4, REPLACE 

G0 


第 4 部 分 
模拟 试题 及 参考 答案 


学 习 导读 ; 
本 部 分 包括 6 套 SQL Server 数据 库 的 模拟 试题 和 参考 答 
案 , 涵 盖 了 本 课程 的 主要 知识 点 ,可 以 帮助 读者 了 解 和 检验 自己 
的 学 习 情 况 。 
前 5 套 是 以 SQL Server 基本 知识 和 基本 操作 为 重点 内 
容 , 第 6 套 添加 了 数据 库 设计 方面 的 内 容 。 


SQL Server 数据 库 模 拟 试 题 1 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 , 总 计 100 分 。 


一 、 选 择 题 (每 题 1 分 , 共 15 分 ) 
1. 语句 SELECT DATENAME( year, getdate()) AS 'Date' 的 输出 结果 为 


A. Date B. 当前 日 期 C. 当前 年 份 D. 当前 时 间 
2. 如 果 SQL Server 的 管理 员 想 在 某 数 据 库 的 日 志文 件 大 小 超过 设 定 值 的 70% 时 能 够 
收 到 通知 ,以 便 及 时 进行 数据 清理 和 增加 磁盘 空间 ,应 该 创建 一 个 类 型 的 警报 。 
A. 事件 B. 性 能 条 件 C. 触发 器 D. 日 志 


3. 数据 库 管理 员 用 以 下 语句 建立 了 一 个 新 表 。 


CREATE TABLE emp_info( emp_ID int PRIMARY KEY, emp_Name varchar (50) UNIQUE, emp_Address 
varchar(50) UNIQUE) 


系统 在 该 表 上 自动 创建 索引 。 

A. 复合 B. 唯一 C. 聚集 D. 非 聚 集 
4. 死 锁 现象 发 生 的 原因 是 

A. 并 发 控制 B. 服务 器 故障 C. 数据 错误 D. 操作 失误 
5. 使 用 游标 处 理 结 果 集 时 ,其 基本 过 程 不 包括 步骤 。 

A. 打开 游标 B. 关闭 游标 C. 游标 府 套 D. 释放 游标 
6. 监视 SQL Server 的 性 能 对 象 时 ,通常 不 关注 2 

A. 磁盘 读 写 B. CPU 使 用 率 C. 打印 速度 D. 内 存 用 量 
7. 分 为 多 个 文件 的 超大 型 数据 库 (VLDB) 进 行 数据 库 备份 时 ,应 选择 策略 。 

A. 完全 数据 库 备份 B. 数据 库 文件 或 文件 组 备份 

C. 差异 备份 D. 全 数据 库 和 事物 日 志 备份 
8. 默认 情况 下 ,SQL Server 2016 的 系统 数据 库 有 从 

A. 10 B. 5 C4 D. 6 
9. 在 存 有 数据 的 表 上 建立 聚集 索引 ,可 以 引起 表 中 数据 的 发 生变 化 。 

A. 逻辑 关系 B. 记录 结构 C. 物理 位 置 D. 列 值 
10. SQL Server 2016 中 的 视图 存在 数据 的 是 o 

A. 标准 视图 B. 索引 视图 C. 所 有 视图 D. 以 上 都 不 对 
11. 下 列 角 色 中 角色 没有 成 员 。 

A. 固定 服务 器 B. 数据 库 C. 应 用 程序 D. public 
12. SQL Server 数据 库 文件 有 三 类 ,其 中 日 志文 件 的 后 级 为 . 

A. .ndf B. .1df C. .mdf D. .idf 
13. 下 面 语句 中 ， 语句 用 来 删除 视图 。 

A. CREATE TABLE B. ALTE VIEW 


C. DROP VIEW D. CREATE VIEW 


SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 志 指 时 


14. 对 于 撤销 权限 的 不 正确 描述 是 5 
A. 可 以 撤销 已 授予 权限 
B. 不 能 利用 REVOKE 语句 撤销 已 拒绝 权限 
C. 可 以 撤销 已 拒绝 权限 
D. 可 以 利用 REVOKE 语句 撤销 已 授予 权限 
15. 作业 是 由 一 系列 SQL Server 代理 顺序 执行 的 指定 操作 ,不 能 执行 。 
A. 触发 有 手下 
C. 调度 D. 触发 警报 
二 、 填空 题 (每 空 1 分 , 共 15 分 ) 
1. 在 SQL Server Management Studio 中 ， 窗口 主要 显示 用 户 经 常 管理 的 数据 
库 服务 器 的 列表 ， 窗口 用 于 显示 数据 库 服务 器 中 的 所 有 数据 库 对 象 。 
2. 在 SQL Server 2016 系统 中 ,一 个 数据 库 至 少 有 一 个 文件 和 一 个 
文件 。 而 数据 库 中 表 的 关联 就 是 约束 。 
3. 数据 库 关系 图 中 ,如 果 关 系 连 线 两 端 都 为 钥匙 图 标 , 则 关系 类 型 为 ; 如 果 
关系 连 线 一 端 为 钥匙 图 标 , 另 一 端 为 c= 图 标 , 则 关系 类 型 为 8 
4. Transact-SQL 语句 基本 表 定 义 有 、 、 和 4 个 表 
级 约束 。 
5. 当 指 定 基本 表 中 某 一 列 或 若干 列 为 主键 时 ,系统 将 在 这 些 列 上 自动 建立 一 个 
、 的 索引 。 
6. SELECT 查询 语句 中 两 个 必 不 可 少 的 子 句 是 和 WHERE 子 句 。 
7. 在 SQL Server 2016 中 不 仅 可 以 通过 视图 检查 基本 表 中 的 数据 ,而 且 还 可 以 向 基本 
表 中 添加 或 修改 数据 ,但 是 所 插入 的 数据 必须 符合 基本 表 中 的 
三 、 简 答题 (每 题 5 分 , 共 20 分 ) 
1. 简 述 SQL Server Management Studio 界面 的 主要 功能 。 
2. SQL 脚本 执行 的 结果 有 哪 几 种 形式 ?查看 SQL 脚本 的 方法 有 哪些 ? 
3. 如 果 给 某 用 户 授 予 更 新 表 的 权限 ,但 该 用 户 所 属 角色 又 拒绝 了 此 权限 ,那么 该 用 户 
账户 是 否 保留 更 新 表 的 权限 ? 阐述 原因 。 
4. 简 述 使 用 SQL Server 代理 的 一 般 步 又 。 
四 、 综 合 题 (每 题 5 分 , 共 50 分 ) 
利用 SQL Server 语句 完成 操作 。 在 数据 库 product_sales 中 参考 下 列表 的 结构 ， 
product( 产 品 编号 char(10) primary key, 
分 类 号 char(6)， 
产品 名 char(30) not null unique, 
库存 量 int, 
订货 点 int, 
单价 float(5,2)) 
order_details( 产 品 编号 char(10) references product( 产 品 编号 )， 
订单 编号 char(10) references c_order( 订 单 编号 )， 
订购 数量 (int)) 


c_order( 订 单 编号 char(10) primary key, 
客户 编号 char(10) references consumer( 客 户 编号 )， 


订购 日 期 datetime) 
consumer( 客 户 编号 char(10) primary key, 
客户 名 称 varchar(30)， 
联系 人 char(16)， 
联系 电话 char(12)) 
. 查询 单价 介 于 50 一 100 元 的 产品 。 
. 查询 产品 订购 总 数量 大 于 3500 的 产品 名 称 及 产品 订购 总 数量 。 
. 查询 2017 年 10 月 开始 没有 下 订单 的 客户 信息 。 
. 将 订单 编号 开头 为 2017 的 订单 所 订购 的 产品 数量 加 倍 。 
.删除 c_order 表 中 所 有 2015-10-01 以 前 的 订单 信息 。 
. 查询 所 有 订单 编号 以 2017 开头 的 产品 的 订购 客户 信息 。 
. 给 consumer 表 增 加 一 个 “备注 ? 列 ,数据 类 型 为 text, 不 允许 为 空 。 
. 按 产品 编号 分 组 ,计算 product 表 中 每 种 产品 的 库存 量 及 资金 额度 。 输 出 资金 额度 
较 大 的 前 10 种 产品 数据 。 
9. 使 用 alter table 语句 在 order_details 表 上 的 订单 编号 列 添加 索引 , 取 名 为 index_ 
details 。 
10. 设置 触发 器 tri_update, 实 现在 product 表 中 修改 产品 编号 时 ,可 自动 修改 课程 在 
order_details 上 的 产品 编号 。 


Im DL- 
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一 、 选 择 题 (每 题 1 分, 共 15 分 ) 

1~5. CBCAC 6 一 10. CBBCB 11~15. CBCBA 

二 、 填空 题 (每 空 1 分 , 共 15 分 ) 

1. 已 注册 的 服务 器 ”对 象 资源 管理 器 。 2. 主 数 据 日 志 外 键 3. 一 对 一 一 对 多 

4. CHECK 约束 UNIQUE 约束” FOREIGN KEY 约束 PRIMARY KEY 约束 

5. 聚集 唯一 6. FROM 子 句 ”7. 列 类 型 和 约束 条 件 

三 、 简 答题 (每 题 5 分 , 共 20 分) 

1. SQL Server Management Studio 是 SQL Server 2016 系统 中 最 重要 的 管理 工具 ， 
也 是 SQL Server 2016 的 可 视 化 集成 环境 ,用 于 访问 .配置 和 管理 SQL Server 2016 的 
组 件 。 

数据 库 管 理 员 可 以 通过 图 形 界面 调用 其 他 管理 工具 来 完成 日 常 管理 操作 ,并 与 Visual 
Studio 开发 平台 集成 在 一 起 ,形成 了 一 个 集 数 据 库 的 管理 与 应 用 开发 风格 一 致 的 界面 环境 ， 
用 于 完成 SQL Server 2016 的 最 基本 操作 。 

2. 选择 输出 格式 可 以 通过 工具 栏 方式 ,也 可 以 通过 “查询 ”>“ 将 结果 保存 到 ”菜单 命令 
方式 。SQL 脚本 执行 的 结果 通常 有 如 下 三 种 形式 : 以 文本 格式 显示 结果 、 以 网 格 显示 结果 
及 将 结果 保存 到 文件 。 查 看 SQL 脚本 的 方法 可 以 通过 查询 设计 器 进行 ,也 可 以 通过 文本 方 
式 进行 。 

3. 该 用 户 不 再 保留 更 新 表 的 权限 。 因 为 拒绝 权限 优先 级 高 ,可 以 使 授予 给 他 的 权限 
失效 。 

4. 使 用 SQL Server 代理 的 一 般 步 骤 如 下 : 

(1) 确定 管理 任务 内 容 、 服 务 器 事件 定期 执行 ,以 及 这 些 任 务 或 事件 是 否 可 以 通过 编程 
方式 进行 管理 。 

(2) 如 果 任 务 涉 及 一 系列 步骤 并 且 在 特定 的 时 间或 响应 特定 事件 执行 , 则 该 任务 适合 
使 用 SQL Server 代理 进行 自动 化 处 理 。 

(3) 使 用 SQL Server 管理 平台 、Transact-SQL 脚本 或 SQL 管理 对 象 定义 一 组 作业 、 计 
划 、 警 报 和 操作 员 。 

(4) 在 SQL Server 代理 中 运行 已 经 定义 的 作业 。 

四 、 综 合 题 (每 题 5 分 , 共 50 分 ) 


1. select* from product 
where 单价 between 50 and 100; 


2. select p. 产品 名 称 ，sum( od. 订购 数量 ) 
from product as p, Order details as od 
where p. 产品 编号 = od. 产品 编号 
group by od. 产品 编号 ,p. 产品 名 称 
having sum(od. 订购 数量 )> 3500; 


select * from consumer 
where 客户 编号 not in 
(select distinct 客户 编号 
from  c_order 
where 订购 日 期 >=2017- 10- 01); 


update Order_details set 订购 数量 = 订购 数量 * 2 
where 订单 编号 like '2017 多 '; 


delete c order 
where 订购 日 期 <'2015 - 10- 01' 


select * from consumer, c_order 


on consumer. 客户 编号 =c_order. 客户 编号 
where c_order. 订单 编号 like '%2017% '; 


alter table consumer 


add column 备注 text not null; 


selecttop 10 产品 编号 , count( 库 存量 ), count( 库 存量 ) * 单价 
from product 

group by 产品 编号 

order by count( 库 存量 ) * 单价 desc 

alter table order details 

add index index_details (订单 编号 ); 


10. create trigger tri_update 


after update on product for each row 
update order_details set order_details, 产品 编号 = new. 产品 编号 
where order_details. 产品 编号 = old. 产品 编号 ; 
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说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 , 总 计 100 分 。 


一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 
1. 运算 符 % 能 够 用 于 以 下 类 型 的 数据 上 。 
A. float B. money C. smallint D. smallmoney 


2. 执行 下 面 语句 的 结果 是 


PRINT UPPER( LTRIM(RTRIM( 'Hello, world') )) 


A. HELLO,WORLD B. Hello,world 
C. Hello,world D. HELLO,WORLD 

3. PRINT DATEDIFF(mm,'2018-10-26','2018-10-8') 的 执行 结果 是 。 
A. 0 B. 一 1 让: 下 多 


4. 陈述 K: COMPUTE 子 句 在 查询 结果 中 使 用 聚合 函数 产生 出 汇总 行 。 陈 述 M: 关 
键 字 DISTINCT 不 能 与 聚合 函数 一 起 使 用 。 关 于 对 以 上 陈述 的 描述 中 ,正确 的 
是 。 


A. 陈述 正确 、M 错误 B. 陈述 K 错误 、M 正确 
C. 都 错误 D. 都 正确 
5. 数据 库 备份 时 ,执行 差异 备份 和 事物 日 志 备 份 都 需要 有 一 个 备份 作为 基准 。 
A. 完全 数据 库 B. 数据 库 文件 或 文件 组 
C. 差异 D. 完全 数据 库 和 事物 日 志 
6. 使 用 下 列 语句 可 以 删除 数据 库 。 
A. DROP DATABASE B. CREATE TABLE 
C. ALTER DATABASE D. DROP TABLE 
7. 下 面 对 union 的 描述 正确 的 是 。 


A. 任何 查询 语句 都 可 以 用 union 来 连接 

B. union 只 连接 结果 集 完 全 一 样 的 查询 语句 

C.union 是 筛选 关键 词 ,然后 对 结果 集 进行 操作 

D. union 可 以 连接 结果 集中 数据 类 型 个 数 相同 的 多 个 结果 集 


8. 下 列 选 项 中 可 以 实现 引用 完整 性 。 

A. rule B. foreign key C. not null D. default 
9. WITH CHECK OPTION 属性 是 对 视图 进行 。 

A. 检查 约束 B. 删除 监测 C. 更 新 监测 D. 插入 监测 
10. 在 表 上 创建 FOR UPDATE 触发 器 后 ,更 新 后 的 数据 放 在 临时 表 中 。 

A. deleted B. temp C. inserted D. sysfile 
11. Transact-SQL 语句 中 的 命令 可 以 撤销 SQL Server 用 户 对 象 权限 。 


A. REVOKE B. GRANT C. DENY D. CREATE 


12. 配置 SQL Server 2016 的 网 络 时 ,只 有 本 地 客户 端 和 服务 器 之 间 连 接 时 ,可 以 使 用 


协议 。 
A. 共享 内 存 B. 命名 管道 人 CTCB/ 赴 D. VIA 
13. 在 存 有 数据 的 表 上 建立 非 聚 集 索 引 , 可 以 引起 表 中 数据 的 发 生变 化 。 
A. 记录 结构 B. 物理 位 置 C. 逻辑 关系 D. 列 值 
14. 数据 库 快 照 可 以 通过 来 实现 。 
A. 存储 过 程 B. 触发 器 
C. 数据 库 备 份 D. Transact-SQL 语句 
15. SQL Server 2016 的 5 种 约束 机 制 中 不 包括 . 
A. check B. not null C. unique D. default 
16. SQL Server 2016 中 的 视图 存在 数据 的 是 。 
A. 标准 视图 B. 所 有 视图 C. 索引 视图 D. 以 上 都 不 对 
17. 当 尚 未 对 某 个 数据 库 用 户 授 予 或 拒绝 对 安全 对 象 的 特定 权限 时 ,该 用 户 具 有 
的 权限 。 
A. db_owner B. public C. sysadmin D. guest 
18. 用 于 联机 事务 处 理 的 数据 库 称 为 数据 库 。 
A. OLAP BQLTP C. 系统 D. 用 户 
19. 在 WHILE 循环 语句 中 ,如 果 循环 体 语句 条 数 多 于 一 条 ,必须 使 用 。 
A. BEGIN…END B. CASE:…END C. IF*…THEN D. GOTO 
20. 下 面 描 述 错误 的 是 


A. 每 个 数据 文件 中 有 且 只 有 一 个 主 数据 文件 
B. 日 志文 件 可 以 存在 于 任意 文件 组 中 
C. 主 数据 文件 默认 为 primary 文件 组 
D. 文件 组 是 为 了 更 好 地 实现 数据 库 文件 组 织 
二 、 填空 题 (每 空 1 分 , 共 10 分) 
1. 在 SQL Server 中 , @ @ ROWCOUNT 变量 将 返回 受 上 一 条 SQL 语句 影响 
的 四 
. 如果 表 的 主键 列 上 取 值 为 NULL .那么 它 违反 了 关系 的 完整 性 约束 。 
. 在 SELECT 语句 中 用 关键 字 消 除 重复 行 。 
. SELECT 语句 的 子 句 可 以 改变 输出 结果 行 的 排序 。 
可 以 用 命令 来 修改 存储 过 程 。 
函数 能 将 一 个 表达 式 从 一 种 数据 类 型 改变 为 另 一 种 数据 类 型 。 
. Transact-SQL 语言 中 ,用 于 事务 回 滚 的 语句 是 和 
. SQL Server 2016 提供 多 个 图 形 化 工具 ,其 中 用 来 启动 、 停 止 和 和 暂停 SQL Server 的 
图 形 化 工具 称 为 
9. Transact-SQL 语言 集 数据 查询 .数据 操纵 、 数 据 定义 和 数据 控制 功能 为 一 体 , 其 中 
语句 REVOKE 是 实现 功能 。 


co 站 呆 叫 上 
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10. 聚合 函数 能 统计 一 个 表 中 包含 多 少 行 。 

三 、 简 答题 (每 题 5 分 , 共 20 分 ) 

1. 什么 是 差异 数据 库 备 份 ? 

2. 简 述 SQL Server 2016 的 两 个 系统 数据 库 model 和 tempdb 的 功能 。 

3. 简 述 游标 的 基本 功能 和 使 用 步骤 。 

4. 简 述 创建 视图 的 意义 和 优点 。 

四 、 综 合 题 ( 每 题 5 分 , 共 50 分 ) 

1. 利用 Transact-SQL 语句 完成 操作 。 

(1) 创建 一 个 名 字 为 JXGL 的 数据 库 ,该 数据 库 包含 一 个 数据 文件 和 一 个 日 志文 件 , 偿 
辑 文件 名 为 JxglL_DB_data ,磁盘 文件 名 为 JxglDB_data. mdf, 文 件 初始 容量 为 5MB, 最 大 容 
量 为 15MB, 文 件 递增 容量 为 1MB。 而 事务 日 志文 件 的 逻辑 文件 名 为 JxglL_DB_log ,磁盘 文 
件 名 为 JxglDB_log. ldf ,文件 初始 容量 为 5MB, 最 大 容量 为 10MB, 文 件 递增 量 为 1MB( 数 据 
库 创建 在 D:\SERVER 文件 夹 下 )。 

(2) 给 名 字 为 JXGL 的 数据 库 添加 一 个 名 字 为 GROUPJX 的 文件 组 。 

(3) 向 数据 库 JXGL 添加 一 个 数据 文件 ,文件 的 逻辑 名 为 JxglDB2_data, 磁 盘 文 件 名 为 
JxglDB_data. ndf ,初始 容量 为 1MB, 最 大 容量 为 50MB, 文 件 递增 量 为 2MB, 将 这 个 数据 文 
件 添 加 到 上 题 建立 的 名 为 GROUPJX 的 文件 组 内 。 

(4) 将 对 数据 库 JXGL 中 SCORE 表 的 SELECT 权限 授予 数据 库 用 户 USER2 。 

(5) 在 数据 库 JXGL 中 对 表 teacher 创建 一 个 触发 器 ,如 果 添 加 的 教师 工资 超过 5000， 
则 拒绝 插入 该 记录 ( 设 每 次 只 插入 一 条 记录 即 可 ) 。 

teacher 表 的 表 结 构 如 下 : 


teacher(tno nchar(10), tname nchar(8), dept nchar(5), pay tinyint) 


其 中 tno 代表 教师 编号 , tname 代表 教师 姓名 , dept 代表 教师 系 别 , pay 代表 教师 的 
工资 。 
2. 根据 下 列 数据 库 中 表 的 结构 回答 问题 并 写 出 Transact-SQL 语句 。 
学 生 ( 学 号 nchar(8) primary key, 姓名 nchar(8), 班 级 nchar(10)， 
性 别 nchar(2), 出 生日 期 ndatetime, 出 生 城市 nchar(10)， 
入 学 成 绩 tinyint) 
课程 (课程 号 nchar(6) primary key, 课 程 名 nchar(20)) 
学 生 选 课 信息 表 ( 学 期 nchar(2), 学 号 nchar(8) references 学 生 ( 学 号 )， 
课程 号 nchar(6) references 课程 (课程 号 )， 
成 绩 tinyint check( 成 绩 > = 0 and 成 绩 < = 100) 
(1) 查询 缺少 成 绩 的 学 生 的 学 号 和 相应 的 课程 号 。 
(2) 查询 17 物流 01 班 全 体 学 生 的 学 号 与 姓名 , 且 按 照 人 学 成 绩 的 降序 排列 。 
(3) 统计 平均 人 学 总 分 在 550 以 上 的 班级 和 这 些 班 级 的 平均 人 学 总 分 。 
(4) 查询 选修 了 “实用 英语 ”课程 的 学 生 的 学 号 ,以 及 实用 英语 的 成 绩 。 
(5) 查询 第 一 学 期 所 选课 程 平均 成 绩 前 三 名 的 学 生 的 学 号 和 姓名 。 
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一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 

1~5.CAADA 6~10. ADBAC 11~15. AACDD 16~20. CDBAB 

二 、 填空 题 (每 空 1 分 , 共 10 分 ) 

1. 行 数 2. 域 3. distince 4. order by 5. alter procedure 

6. cast() 7. rollback 8. 服务 管理 器 9. 撤销 权限 10. count() 

三 、 简 答题 (每 题 5 分 , 共 20 分 ) 

1. 差异 数据 库 备 份 只 是 记录 自 上 次 数据 库 备 份 后 发 生 更 改 的 数据 。 差 异 数据 库 备 份 
比 数据 库 备份 小 ,而 且 速 度 快 。 

2. model 是 在 SQL Server 系统 上 创建 数据 库 的 模板 。 创 建 数据 库 时 ,新 数据 库 的 第 
一 部 分 通过 复制 model 数据 库 中 的 内 容 创建 ,剩余 部 分 由 空 页 填充 。tempdb 系统 数据 库 用 
于 存放 所 有 的 临时 表 和 临时 存储 过 程 。 

3. 游标 是 SQL Server 每 次 对 应 用 程序 结果 集 的 一 行 或 多 行进 行 处 理 的 一 种 技术 。 

4. 创建 视图 可 以 将 数据 集中 显示 ,简化 用 户 的 数据 查询 和 处 理 ,简化 数据 操作 ,屏蔽 数 
据 库 的 复杂 性 。 组 合 分 区 数据 可 将 来 自 不 同 表 的 多 个 查询 结果 组 合成 单一 的 结果 集 , 利 用 
用 户 查 询 和 使 用 。 重 新 定制 数据 ,使 得 数据 便于 共享 。 

意义 : 简化 用 户 权 限 的 管理 ,增强 了 安全 性 。 为 数据 库 重 构 提 供 一 定 的 逻辑 独立 性 。 

四 、 综 合 题 ( 每 题 5 分. 共 50 分 ) 


1. (1) Create database JXGL ON 

(NAME = JXGL_DB_data, 
FILENAME = 'D:\server\JXGLDB data. mdf', 
SIZE = 5mb, 
MAXSIZE = 15mb, 
FILEGROWTH = lmb 

》 

LOGON ( 
NAME = JXGL_DB_log, 
FILENAME = 'D:\server\JXGLDB_log. ldf', 
SIZE = 5mb, 
MAXSIZE = 10mb, 
FILEGROWTH = 1mb 

d 


(2) ALTER DATABASE JXGL 
ADD FILEGROUP GROUPJX 


(3) ALTER DATABASE JXGL 
ADD FILE 
( NAME = JXGLDB2_data, 
FILENAME = 'd:\server\JXGLDB data. ndf', 
size= lmb, 


SQL Server 2016 数据 亩 应 用 与 开发 习题 解答 与 上 志 指 时 


maxsize = 50MB, 
filegrowth = 2MB 
) 
To filegroup GROUPJX 
(4) USE JXGL 
GO 
GRANT SELECT ON SCORE TO USER2 


(5) Create trigger trigger change 
on teacher 
AFTER INSERT 
RS 
IF(SELECT pay FROM inserted )> 5000 
BEGIN 
PRINT’ 新 教师 工资 不 得 超过 5000' 
ROLLBACK 
END 


2. (1) select 学 号 ,课程 号 
from 学 生 选 课 信息 表 
where 成 绩 is null 


(2) select 学 号 ,姓名 
from 学 生 
where 班级 = '17 物流 01 
order by 人 学 成 绩 desc 
(3) select 班级 ,avg( 人 学 成 绩 ) 
from 学 生 
group by 班级 
having avg( 人 学 成 绩 )> 550 
(4) select 学 号 ,成 绩 
from 学 生 选 课 信息 表 
where 课程 号 = (select 课程 号 
from 课程 
where 课程 名 = ' 实 用 英语 ' 
) 


(5) select top 3 学 生 选 课 信息 .学 号 ,学 生 . 姓名 
from 学 生 选 课 信 息 ,学 生 
where 学 生 选 课 信息 .学 期 = '1'and 学 生 选 课 信 息 . 学 号 = 学生. 学 号 
group by 学生 选课 信息 .学 号 
order by avg( 成 绩 ) 
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说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 , 总 计 100 分 。 


一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 


1. 下 面 标 志 符 不 合法 的 是 。 

A. [my delete] B. _mybase C. $money D. triggerl 
2. SQL Server 2016 的 数据 库 无 处 不 在 的 数据 危险 不 包括 故障 。 

A. 系统 B. 计划 C. 介质 D. 事务 
3. 进行 数据 库 的 完整 性 设计 时 ,不 包括 方法 。 

A. check B. trigger C. rule D. insert 
4. 聚合 函数 与 SELECT 语句 中 的 子 句 配合 使 用 ,可 以 实现 对 一 组 值 执行 计 

算 并 返回 单一 值 。 

A. where B. into C. group by D. having 
5. 在 存 有 数据 的 表 上 建立 聚集 索引 ,可 以 引起 表 中 数据 的 发 生变 化 。 

A. 表 间 关系 B. 物理 位 置 C. 记录 结构 D. 列 值 
6. 用 于 联机 分 析 处 理 的 数据 库 称 为 数据 库 。 

A. OLAP B: OLTP C. 系统 D. 用 户 
7. 下 列 函数 中 ,返回 值 数 据 类 型 为 int 的 是 。 

A. LEFT B. LEN 

C. LTRIM D. SUNSTRING 
8. 下 列 操作 中 ， 不 是 SQL Server 服务 器 管理 器 功能 。 

A. 启动 SQL Server 服务 B. 停止 SQL Server 服务 

C. 执行 SQL 查询 命令 D. 暂停 SQL Server 服务 
9. 表达 式 Datepart(yy,'2018-9-13') 十 2 的 结果 是 

A. '2018-9-15" B. 2018 C. '2018” Dy “2018=11=13" 
10. 语句 print cast(123 as nchar(5) ) 十 '456' 的 结果 是 

A. '579' B. 579 CG. "123456" D. '123 456' 
11. 下 列 数 据 库 中 ,属于 SQL Server 2016 系统 数据 库 的 是 数据 库 。 

A. AdventureWorks B. tempdb C. teaching D. distmodel 
12. 关于 SQL Server 2016 数据 库 事务 日 志文 件 ,叙述 错误 的 是 


A. 一 个 数据 库 至 少 有 一 个 事务 日 志文 件 
B. 创建 数据 库 时 ,如 果 未 指定 事务 日 志文 件 ,SQL Server 会 自动 创建 一 个 
C. 事务 日 志文 件 的 默认 大 小 为 1MB 
D. 如 果 未 指定 事务 日 志文 件 的 增长 量 , 则 文件 大 小 保持 不 变 
13. 关于 DROP DATABASE 语句 叙述 错误 的 是 。 
A. 一 次 可 以 删除 一 个 或 多 个 数据 库 
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B. 在 删除 数据 库 时 不 会 显示 确认 信息 
C. 会 删除 数据 库 的 磁盘 文件 
D. 如 果 数 据 库 正 在 使 用 ,删除 数据 库 将 导致 应 用 程序 出 错 
14. 下 列 关于 执行 SQL Server 2016 查询 叙述 正确 的 是 四 
A. 如 果 没 有 选中 的 命令 , 则 只 执行 最 前 面 的 第 一 条 命令 
B. 如 果 有 多 条 命令 选择 , 则 只 执行 选中 命令 中 的 第 一 条 命令 
C. 如 果 查 询 中 有 和 多 条 命令 有 输出 , 则 按 顺序 显示 所 有 结果 
D. 都 正确 
15. 下 列 关 于 SQL Server 2016 查询 结果 错误 的 是 
A. 查询 结果 可 以 显示 在 表格 中 
B. 查询 结果 可 以 按 文本 方式 显示 
C. 以 文本 和 表格 显示 的 查询 结果 在 保存 时 ,其 格式 不 同 
D. 不 管 以 哪 种 方式 查看 ,查询 结果 都 会 显示 在 查询 结果 窗口 中 


16. 对 数据 进行 统计 时 , 求 最 大 值 的 函数 是 

A. max() B. min() C. lenthO) D. count() 
17. 命令 truncate table 的 功能 是 。 

A. 清空 表 B. 删除 表 数 据 C. 删除 表 D. 更 新 表 数 据 
18. 用 户 对 数据 进行 添加 、 修 改 和 删除 时 ,自动 执行 的 存储 过 程 称 为 

A. 脚本 B. 用 户 存储 过 程 ”C. 系统 存储 过 程 ”D. 触发 器 
19. 下 列 不 可 以 为 视图 授予 的 权限 是 。 

A. SELECT B. UPDATE C. EXEC D. DELETE 
20. 在 设置 操作 员 时 可 以 选择 使 用 的 发 送 通知 方式 不 包括 。 

A. 网 络 发 送 B. 呼叫 程序 C. 电子 邮件 D. 博客 
二 、 填 空 题 (每 空 1 分 , 共 10 分 ) 
1. 将 数学 表达 式 Viab 一 c*| 写 成 SQL Server 表达 式 的 形式 为 。 
2. 访问 SQL Server 2016 数据 库 对 象 时 ,需要 经 过 身份 验证 和 两 个 阶段 ,其 中 

身份 验证 分 为 Windows 验证 模式 和 验证 模式 。 


可 是 存储 在 文件 中 的 一 系列 SQL 请 句 , 即 一 系列 按 顺序 提交 的 批 处 理 。 

4. SQL Server 2016 使 用 文件 记载 用 户 对 数据 库 进行 的 所 有 操作 。 

5. sp_helpdb 系统 存储 过 程 的 功能 是 

6. SQL Server 2016 中 的 变量 分 为 全 局 变量 和 局 部 变量 两 种 。 其 中 全 局 变量 的 名 称 以 

字符 开始 ,由 系统 定义 和 维护 。 局 部 变量 以 ” 字符 开始 ,由 用 户 自己 定义 和 

赋值 。 

7. 在 SQL Server 2016 中 ,其 权限 可 以 分 为 权限 、 权限 和 隐 含 权限 
三 类 。 

三 、 简 答题 (每 题 5 分 , 共 20 分 ) 

1. 简要 说 明 事务 的 原子 性 。 

2. 简单 说 明 排 它 锁 和 它 的 作用 。 

3. 简 述 SQL Server 2016 备份 数据 库 时 需要 执行 的 操作 。 


4. 简 述 监视 SQL Server 系统 的 主要 指标 。 

四 、 综 合 题 (每 题 5 分 , 共 50 分 ) 

1. 使 用 Transact-SQL 语句 完成 操作 。 

(1) 利用 命令 创建 一 个 数据 库 jiaowu, 具 体 文件 属性 如 下 表 所 示 。 


jiaowu 数据 库 参 数 表 

参 数 参数 值 
数据 库 名 jiaowu 
逻辑 数据 文件 名 jiaowu_dat 
操作 系统 数据 文件 名 D:\ jiaowu_dat. mdf 
数据 文件 的 初始 值 2MB 
数据 文件 的 最 大 值 20MB 
数据 文件 增长 幅度 2MB 
日 志 人 逻辑 文件 名 jiaowu_log 
操作 系统 日 志文 件 名 D:\ jiaowu_log. ldf 
日 志文 件 初始 值 1MB 
日 志文 件 增长 幅度 15% 


(2) 修改 jiaowu 数据 库 , 添 加 次 要 数据 文件 参数 如 下 表 所 示 。 


jiaowu 数据 库 文件 参数 表 
参数 参数 值 

文件 组 myfilegroup 

逻辑 数据 文件 名 jiaowu_dat3 

操作 系统 数据 文件 名 D:Njiaowu_dat3. ndf 
数据 文件 的 初始 值 2MB 

数据 文件 的 最 大 值 20MB 

数据 文件 增长 幅度 2MB 


(3) 利用 create table 命令 创建 学 生 、 课 程 、 选 课 三 个 表 , 并 查询 姓名 为 “黄岩 ”的 学 生 所 


选课 程 的 “课程 名 ”及 “成 绩 ”。 


学 生 (序号 int, 学 号 nchar(9), 姓 名 varchar(10), 住 址 varchar(20)， 


性 别 nchar(2), 系 名 nchar(20)) 


课程 (课程 号 nchar(6), 课 程 名 varchar(30), 学 时 int, 教师 编号 nchar(6)) 


选课 (学 号 nchar(9), 课 程 号 nchar(6), 成 绩 int ) 


(4) 创建 视图 Vsqlupdate, 检 索 所 有 选修 课程 号 为 051026 的 学 生 学 号 .课程 号 及 成 绩 。 
(5) 创建 存储 过 程 updatecourse, 修改 课程 名 称 时 ,提示 输入 参数 为 课程 号 ,输出 参数 


为 新 的 课程 名 称 。 


(6) 在 jiaowu 数据 库 中 创建 应 用 程序 角色 jsjrole。 
2. 利用 命令 实现 下 列 操作 : 


(1) 添加 登录 名 为 tuser, 密 码 为 123abc 的 SQL 登录 账户 ,并 映射 为 数据 库 jiaowu 的 
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数据 库 用 户 tuserindb。 然 后 配置 权限 如 下 : 

(2) 对 数据 库 jiaowu 具有 创建 数据 表 、 创 建 存储 过 程 、 创 建 视图 、 创 建 规则 、 备 份 数 据 
库 的 权限 。 

(3) 授予 对 数据 表 学 生 的 列 (学 号 、 姓 名 ) 进 行 查询 的 权限 。 

(4) 拒绝 对 数据 表 课 程 的 插入 更新、 删除 权限 ,撤销 执行 存储 过 程 Pro 权限 。 
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一 、 选 择 题 (每 题 1 分 , 共 20 分) 

1~5.CBDCB 5 一 10. ABCCD 11~15. BDDCD 16~20. AADCD 
二 、 填空 题 (每 空 1 分 , 共 10 分 ) 

SQRT(ABS(axb 一 ce*3) ”2. 权 限 验证 ,混合 ” 3. 脚 本 4. 日 志 
显示 数据 库 的 相关 属性 。 6.@@ @ 7. 对象 语句 

、 简 答题 (每 题 5 分, 共 20 分 ) 

1. 事务 的 所 有 操作 必须 完成 ,否则 事务 将 被 撤销 。 也 就 是 说 ,事务 是 作为 一 个 整体 的 
单位 处 理 , 不 可 以 被 分 割 。 

2. 排 它 锁 又 称 为 写 锁 。 如 果 事 务 T1 对 数据 对 象 X 加 上 排 它 锁 , 则 只 允许 事务 Tl 读 
取 和 修改 数据 项 X, 其 他 任何 事务 都 不 能 对 X 加 任何 类 型 的 锁 , 直 到 Tl 释放 X 上 的 锁 ,从 
而 保证 其 他 事务 在 T1 释放 X 上 的 锁 之 前 不 能 再 读 取 和 修改 X。 

3. 备份 数据 库 的 方法 步骤 大 同 小 异 ,使 用 SQL Server Management Studio 进行 数据 库 
备份 的 基本 操作 包括 选择 需要 备份 的 数据 库 ,设置 “备份 数据 库 ? 对 话 框 中 的 参数 (如 备份 类 
型 .备份 集 的 信息 、 备 份 集 过 期 时 间 、 设 置 数据 库 备份 路 径 或 备份 设备 等 ), 最 后 单 击 “ 确 定 ” 
按钮 即 可 完成 完整 数据 库 备份 。 

4. 监视 SQL Server 系统 的 主要 指标 任务 包括 监视 磁盘 I/O 、 隔 离 SQL Server 产生 的 
磁盘 活动 .使 用 SQL Server: Buffer Manager: Page writes/sec 向 磁盘 写 入 页 ,监视 CPU 以 
定期 监视 Microsoft SQL Server 实例 以 确定 CPU 使 用 率 是 否 在 正常 范围 内 ,监视 处 理 器 的 
使 用 率 ,监视 内 存 等 。 

四 、 综 合 题 (每 题 5 分 , 共 50 分 ) 


1. (1) create database jiaowu 
on( 
name = jiaowu_dat, 


Ne 


filename = 'D:\jiaowu dat. mdf', 
size=2, 
maxsize = 20, 
filegrowth=2 ) 
logon( 
name = 'jiaowu_log', 
filename = 'D:\jiaowu_log. ldf', 
size=1, 
filegrowth=15% ) 
(2) alter database jiaowu 
add file( 
name = 'jiaowu dat2°', 
filename = 'D:\jiaowu dat2.ndf', 
size=2, 
maxsize = 20, 
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filegrowth=2 ) 
(3) create table 学 生 ( 序号 int, 学 号 nchar(9), 姓 名 varchar(10)， 
住址 varchar(20) ,性 别 nchar(2), 系 名 nchar(20)) 
create table 课程 (课程 号 nchar(6), 课 程 名 varchar(30)， 
学 时 int, 教 师 编号 nchar(6)) 
create table 选课 (学 号 nchar(9), 课 程 号 nchar(6) ,成绩 int) 
一 - 查询 姓名 为 ' 黄 岩 ' 的 学 生 所 选课 程 的 "课程 名 "及 "成 绩 " 
select k. 课程 名 ,x. 成 绩 fronm 课程 as k, 学生 as s, 选课 as x 
where k. 课程 号 =x. 课程 号 and s. 学 号 = x. 学 号 and s. 姓 名 = ' 黄 岩 ' 
(4) create view V_sqlupdate 
as 
select * from 选课 where 课程 号 = '051026' 
select * from vw_sqlupdate 


(5) create proc updatecourse 
@courseid nchar(10), @newnamel nchar(50), 
@oldname nchar(10) output, @newname2 nchar(10) output 
as 
set @newname2 = @newnamel 
select @oldname = 课程 名 from 课程 
where 课程 号 = @courseid 
update 课程 set 课程 名 = @newnamel 
where 课程 号 = @courseid 
select * fronm 课程 
declare @namel nchar(10),@name2 nchar(10) 
exec updatecourse '051026', 'SQL 数据 库 编 程 , 
@namel output, @name2 output 
print @namel + ' 已 更 改 为 : '+ @name2 
(6) USE jiaowu 
GO 
CREATE APPLICATION ROLE jsjrole 
WITH DEFAULT_SCHEMA = dbo, PASSWORD = ‘abcdef' 
GO 
2. (1) -- 添加 tuser 登录 账户 
sp_addlogin 'tuser' '123abc' 
一 映射 tuser 为 数据 库 jiaowu 用 户 
use jiaowu 
go 
sp_grantdbaccess 'tuser', 'tuserindb' 
(2) -- 对 数据 库 jiaowu 设置 权限 
grant create table, create proc, Create view, create rule, backup database totuserindb 
(3) -- 授予 对 数据 表 学 生 的 列 (学 号 、 姓 名 ) 进 行 查询 的 权限 
grant select on 学 生 ( 学 号 .姓名 ) to tuserindb 
(4) -- 拒 绝对 数据 表 课 程 的 插入、 更 新 删除 权限 
deny insert, update, delete on 课程 to tuserindb 
--- 撤销 执行 存储 过 程 Pro 权限 


revoke exec on Pro to tuserindb 


区 


10. 


13. 


SQL Server 数据 库 模 拟 试题 4 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 


、 选 择 题 (每 题 1 分 . 共 20 分 ) 


SQL Server 数据 库 文 件 有 三 类 ,其 中 主 数 据 文件 的 后 绥 为 

A， .ndf Bd C. .mdf D. .idf 
. 下 列 命令 用 来 查询 存储 过 程 与 表 之 间 的 相关 性 。 

A. sp_help B. sp_depends C. sp_select D. sp_relyon 
-下列 角色 或 者 用 户 拥有 SQL Server 服务 器 范围 内 的 最 高 权限 。 

A. dbo B. sysadmin C. public D. guest 


. 下面 对 union 的 描述 正确 的 是 。 


A. 任何 查询 语句 都 可 以 用 union 来 连接 

B. union 只 连接 结果 集 完全 一 样 的 查询 语句 

C. union 是 筛选 关键 词 ,然后 对 结果 集 再 进行 操作 

D. union 可 以 连接 结果 集中 数据 类 型 个 数 相 同 的 多 个 结果 集 


. 下 面 语句 中 ， 语句 用 来 创建 视图 。 

A. CREATE TABLE B. ALTE VIEW 

C. DROP VIEW D. CREATE VIEW 
. 使 用 下 列 语句 可 以 删除 数据 库 。 

A. DROP DATABASE B. CREATE TABLE 

C. ALTER DATABASE D. DROP TABLE 
. 关系 运算 不 包括 

A. 连接 B. 投影 C. 选择 D. 查询 
.SQL Server 以 粒度 锁定 资源 ,以 下 粒度 中 级 别 最 低 的 是 

A. RID B. Extent C. Key D. Page 
. 当 对 表 实 施 更 新 时 ,实施 类 型 的 锁定 方式 。 

A. 互 斥 锁 B. 共享 锁 C. 更 新 锁 D. 意向 锁 

实现 域 完整 性 的 机 制 通常 不 包括 

A. 存储 过 程 B. check C. foreign key D. 数据 类 型 
.从 逻辑 角度 看 ,数据 库 对 象 不 包括 

A. 表 B. 日 志文 件 C. 视图 D. 数据 库 
= 操作 会 导致 产生 deleted 表 。 

A. CREATE TABLE B. INSERT 

C. SELECT D. UPDATE 

SQL Server 复制 有 助 于 通过 同步 数据 库 之 间 的 信息 来 维护 数据 一 致 性 。 为 实现 


SQL Server 2016 数据 亩 应 用 与 开发 习题 解答 与 上 所 指 早 


批 处 理 文件 和 脚本 中 的 复制 ,使 用 方法 。 
A. 复制 向 导 和 属性 B. 复制 系统 存储 过 程 
C. 复制 编程 接口 D. Windows 同步 管理 
14. 查询 测验 中 分 数 不 属于 80 一 100 的 候选 人 ,合适 的 查询 语句 是 


A. SELECT vFirstName,vLastName, siTestScore 
FROM ExternalCandidate 
WHERE siTestScore NOT BETWEEN 80 RND 100 


B. SELECT vFirstName, vLastName, siTestScore 
FROM ExternalCandidate 
WHERE siTestScore BETWEEN 80 AND 100 


| 


。 SELECT vFirstName, vLastName, siTestScore 
FROM ExternalCandidate 
WHERE siTestScore NOT BETWEEN 100 AND 80 
D. SELECT vFirstName, vLastName, siTestScore 
FROM ExternalCandidate 
WHERE siTestScore BETWEEN 100 AND 80 


15. 下 面 表示 要 执行 差异 备份 。 
A. RECOVERY B. DIFFERENTIAL 
C. INIT D. NOINIT 
16. 角色 没有 成 员 。 
A. 固定 服务 器 B. 固定 数据 库 C. 应 用 程序 D. public 
17. 用 于 决策 支持 的 数据 库 称 为 数据 库 。 
A. 系统 B. 用 户 © OLTP D. OLAP 
18. 进行 数据 库 的 完整 性 设计 时 ,不 包括 方法 。 
A. Check B. Trigger C. Rule D. Insert 
19. 聚合 函数 实现 对 一 组 值 执行 计算 并 返回 单一 值 ,通常 与 SELECT 语句 中 的 
子 句 配合 使 用 。 
A. WHERE B. INTO C. GROUP BY D. HAVING 
20. SQL Server 2016 的 每 个 数据 文件 的 基本 存储 单位 的 大 小 是 
A. 8K B. 64K C. 8060B D. 64M 
二 、 填空 题 (每 空 1 分 . 共 10 分) 
1. 将 数学 表达 式 A* Bi 十 eY 写 成 表达 式 形 式 为 
2. 函数 ROUND(558. 3049,2) 的 返回 值 是 。 
3. 用 于 删除 表 数 据 的 命令 是 或 
4. 用 SELECT 进行 模糊 查询 时 ,可 以 使 用 匹配 符 , 但 要 在 条 件 值 中 使 用 
或 等 通配符 来 配合 查询 。 并 且 模 糊 查询 针对 的 字段 类 型 是 或 时 
间 类 型 的 查询 。 
5. 计算 字段 的 累加 和 的 函数 是 ,统计 项 目 数 的 函数 是 


三 、 简 答题 (每 题 5 分 , 共 20 分 ) 
1. 说 明 如 何在 SQL Server Management Studio 中 创建 登录 账户 JSJ1801/abcde123。 


2. 简 述 SQL Server 中 系统 数据 库 master 和 msdb 的 主要 功能 。 

3. 简 述 并 发 控制 可 能 产生 的 原因 。 

4. 简 述 在 数据 库 中 创建 索引 的 必要 性 。 

四 、 综 合 题 (每 题 5 分 . 共 50 分 ) 

SQL Server 数据 库 jiaoxue 中 的 “信息 ”和 “成 绩 ” 两 个 表 的 结构 和 数据 如 下 面 两 个 表 所 
示 , 写 出 利用 Transact-SQL 语言 完成 以 下 各 题 的 操作 命令 。 


“信息 ” 表 结 构 和 数据 
学 号 (nchar,4) 姓名 (nchar,8) 性 别 (nchar,2) 入 学 成 绩 (int,4) | 出 生日 期 (datetime) 
0001 男 690 1999-09-22 
0002 女 775 1998-06-07 
0003 689 2000-12-19 
0005 男 668 1999-09-19 


“成 绩 ” 表 结构 和 数据 
学 号 (nchar,4) 课程 编号 (nchar,5) 成 绩 (int, 4) 

0001 13512 72 
0002 11254 91 
0003 21450 89 
0004 31248 63 
0002 32687 99 
0001 21450 85 
0004 13510 97 
0003 11254 69 

写 出 创建 “成 绩 ”" 表 的 命令 。 

显示 平均 成 绩 高 于 85 分 的 学 生 的 学 号 、 姓 名 。 

. 分 别 求 出 男女 学 生 的 平均 入 学 成 绩 。 


. 显示 单 科 成 绩 最 高 的 学 生 的 学 号 、 姓 名 及 课程 编号 。 
. 在 "信息 ” 表 中 的 “学 号 ? 列 上 创建 一 个 非 聚 集 索 引 xh, 若 该 索引 存在 , 则 删除 后 


TD 


重建 。 

6. 建立 视图 View 1, 查 询 所 有 学 生 的 学 号 、 姓 名 和 平均 分 数 。 

7. 创建 一 个 存储 过 程 Delel ,删除 “成 绩 ” 表 中 指定 的 记录 。 

8. 在 “信息 ” 表 上 创建 一 个 触发 器 trigl1, 当 删除 “信息 ” 表 记 录 时 ,同步 删除 “成 绩 ”" 表 中 
指定 的 记录 。 

9. 先 显示 “信息 ” 表 中 的 学 生 人 数 , 开 始 一 个 事务 ,插入 一 条 “信息 ” 表 记 录 , 再 显示 “ 信 
息 ” 表 中 的 学 生 人 数 , 回 滚 该 事务 后 再 显示 “信息 ” 表 中 的 学 生 人 数 。 

10. 为 数据 库 jiaoxue 添加 一 个 名 字 为 Testgroup 的 文件 组 。 


SQL Server 数据 库 柑 所 试题 了 


SQL Server 数据 库 模拟 试题 4 参考 答案 


一 、 选 择 题 ( 每 题 1 分 , 共 20 分 ) 

1~5. CBBDD 6~10. ABAAA 11~15. DDBAB 16~20. CDDCA 

二 、 填空 题 (每 空 1 分 , 共 10 分) 

1. AxBxBxB+EXP(Y) 2. 558. 3000 3. Truncate Table delete 

4. LIKE、% 、、 字 符 型 5. SUM( ) .COUNT( ) 

三 、 简 答题 (每 题 5 分 , 共 20 分 ) 

1. 创建 登录 账户 的 主要 步骤 如 下 : 

(1) 在 SQL Server Management Studio 的 “对 象 资源 管理 器 ”中 右 击 展开 的 “安全 性 ”一 
“登录 名 ”节点 ,在 弹出 的 快捷 菜单 中 选择 “新 建 登录 ”命令 ,打开 对 话 框 。 

(2) 在 “名 称 ” 文 本 框 中 输入 JSJ1801, 在 “身份 验证 ”中 选择 “SQL Server 身份 验证 ”, 在 
“密码 ”文本 框 中 输入 abcdel123, 再 验证 一 次 密码 ,其 他 项 保持 “默认 设置 ”。 

(3) 选择 “服务 器 角色 ”选项 卡 , 选 择 一 个 角色 如 sysadmin 。 

(4) 设置 完成 后 单 击 “ 确 定 ” 按 钮 。 

2. 两 个 数据 库 的 主要 功能 如 下 : 

(1) master 数据 库 是 最 重要 的 SQL Server 系统 数据 库 , 包 含 了 系统 中 有 关 数 据 库 的 所 
有 信息 。 

(2) msdb 是 代理 服务 数据 库 , 为 其 报警 .任务 调度 和 记录 操作 员 的 操作 提供 存储 空间 。 

3. 多 个 用 户 访 问 同一 个 数据 资源 时 可 能 会 出 现 一 些 并 发 问题 ,并 发 控制 可 能 产生 的 原 
因 如 下 : 

(1) 更 新 丢失 。 当 两 个 或 多 个 事务 选择 同一 行 ,每 个 事务 都 不 知道 其 他 事务 的 存在 。 
最 后 的 更 新 将 覆盖 其 他 事务 所 做 的 更 新 ,从 而 导致 数据 丢失 。 

(2) 不 可 重复 读 。 当 一 个 事务 多 次 访问 同一 行 且 每 次 读 取 不 同 数 据 时 会 出 现 不 可 重复 
读 问题 。 

(3) 幻 读 。 当 对 某 行 执行 插入 或 删除 操作 ,而 该 行 属于 某 事务 正在 读 取 的 行 的 范 目 
就 会 出 现 幻 读 问 题 。 

(4) 脏 读 。 即 读 出 的 是 不 正确 的 临时 数据 。 

4. 在 数据 库 中 创建 索引 可 以 大 大 提高 系统 的 查询 性 能 ,加 快 数据 的 检索 速度 ,可 以 保 
证 每 一 行 数据 的 唯一 性 ,加 速 表 与 表 之 间 的 连接 。 

同时 ,在 使 用 ORDER BY 和 GROUP BY 子 句 进行 数据 检索 时 ,可 以 显著 减少 查询 中 
分 组 和 排序 的 时 间 。 在 查询 过 程 中 使 用 查询 优化 器 可 以 提高 系统 性 能 。 

四 、 综 合 题 ( 每 题 5 分 , 共 50 分 ) 

1. create table 成 绩 (学 号 nchar(4) ,课程 编号 nchar(5), 成 绩 int ) 


2. select 信息 .学 号 ,信息 .姓名 fron 信息 
where 信息 .学 号 in (select 成 绩 .学 号 from 成 绩 


上 时 


group by 成 绩 .学 号 
having AVG( 成 绩 .成 绩 )> 85) 


3. select avg( 信 息 . 人 学 成 绩 ) as 平均 人 学 成 绩 ,性 别 fron 信息 


group by 性 别 

4. select 信息 .学 号 ,信息 .姓名 ,信息 .课程 编号 
from 信息 ,成 绩 
where 信息 .学 号 = (select 成 绩 .学 号 from 成 绩 


where 成 绩 . 成绩 = 
(select MAX( 成 绩 .成 绩 )fronm 成 绩 ) ) 


5. IF EXISTS (select name from sysindexes where name = 'xh') 
drop index 信息 .xh 
go 
use student 
create index xh on 信息 (学 号 ) 
go 
exec sp_helpindex 信息 
go 
6. create view View 1 
as 
select 信息 .学 号 ,信息 .姓名 , AVG( 成 绩 ) AS 平均 成 绩 ' 
from 信息 ,成 绩 ”where 信息 .学 号 = 成 绩 .学 号 
group by 信息 .学 号 
go 
7. create procedure Delel @no char(4) = NULL 
as 
IE @NO IS NULL 
begin 
PRINT ' 必 须 输入 学 号 ' 
Return 
End 
delete from 成 绩 where 学 号 = @no 
go 
8. create trigger trigl on 信息 
for delete 
as 
declare @no char(4) 
select @no= 学 号 from deleted 
delete fron 成 绩 Where 学 号 = @no 
If(@@error <>0) 
rollback tran 
else 
commit tran 
go 
9. declare @num int 
select @num= count( * ) from 信息 
begin transaction 
insert into 信息 
values( '0008'，' 海 名 未 ',' 女 ',789, '1999 - 09 -18') 
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select @num = count( * ) from 信息 
rollback 
select @num = count( * ) from 信息 
10. alter database jiaoxue 
add filegroup testgroup 


SQL Server 数据 库 模 拟 试题 5 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 


一 、 选 择 题 ( 每 题 1 分 , 共 15 分 ) 


1. 在 数据 库 中 NULL 表示 
A. 0 B. 空格 C. 未 知 值 D. 其 他 
2. 批 处 理 是 一 个 SQL 语句 集合 ,以 结束 。 
A. BEGIN 有 C. GO D. END 
3. 在 SQL Server 中 回 深 事务 的 命令 为 入 
A. COMMIT B. ROLLBACK C. GOTO D. DECLEAR 
4. 聚合 函数 中 的 可 以 实现 对 一 数值 列 执行 累 加 并 返回 单一 值 。 
A. SUM B. COUNT C. MAX D. SQRT 
5. 在 存 有 数据 的 表 上 建立 非 聚 集 索 引 , 可 以 引起 表 中 数据 的 发 生变 化 。 
A. 表 间 关系 B. 物理 位 置 C. 逻辑 顺序 D. 列 值 
6. 下 列 函数 中 ,返回 值 数据 类 型 为 int 的 是 

A. GETDATE B.; COUNT 

Cc. LTRM D. SUNSTRING 
7. 命令 CREATE DEFAULT 的 功能 是 。 

A. 清空 表 B. 创建 默认 值 C. 创建 触发 器 D. 创建 表 
8. 为 数据 表 创建 索引 的 目的 是 。 

A. 提高 查询 的 检索 性 能 B. 归 类 

C. 创建 主键 D. 准备 创建 视图 
9. 表达 式 Datepart(yy,'2018-9-13') 十 7 的 结果 是 攻 

A.。'2018-9 一 20' B. 2018 C. '2023" D. '2017' 
10. 在 SQL Server 2016 服务 器 上 ,存储 过 程 是 一 组 预先 定义 并 的 Transact- 

SQL 语句 集合 。 

A. 保存 B. 编译 C. 解释 D. 编写 
11. 表 是 SQL Server 数据 库 中 用 来 各 种 数据 内 容 的 数据 库 对 象 。 

A. 显示 B. 查询 C. 存放 D. 检索 
12. 关于 SQL Server 2016 数据 库 事 务 日 志文 件 叙 述 错 误 的 是 


A. 一 个 数据 库 可 以 有 多 个 事务 日 志文 件 
B. 创建 数据 库 时 .如果 未 指定 事务 日 志文 件 ,SQL Server 会 自动 创建 一 个 
C. 事务 日 志文 件 的 默认 大 小 为 5MB 
D. 如 果 未 指定 事务 日 志文 件 的 增长 量 , 则 文件 大 小 也 会 不 断 变化 
13. 下 列 关 于 执行 SQL Server 2016 查询 叙述 正确 的 是 5 
A. 如 果 没 有 选中 的 命令 , 则 只 执行 最 前 面 的 第 一 条 命令 


SQL Server 2016 数据 亩 应 用 与 开发 习题 解答 与 上 志 指 时 


B. 如 果 有 多 条 命令 选择 , 则 只 执行 选中 命令 中 的 第 一 条 命令 
C. 如 果 查 询 中 有 多 条 命令 有 输出 , 则 按 顺 序 显 示 所 有 结果 
D. 遇 到 GO 命令 就 自动 开始 执行 

14. 表达 式 DATENAME(Mm,'2017-11-11') 的 值 是 


pi B. 12 
C. 星期 六 D. '2017-11-11' 
15. 对 数据 库 表 创 建 索引 的 缺点 有 
A. 提高 了 检索 速度 B. 降低 了 数据 修改 速度 
C. 强制 实施 行 的 唯一 性 D. 节省 了 存储 空间 
二 、 填空 题 (每 空 1 分 , 共 15 分 ) 
1. 服务 器 用 来 、 和 停止 SQL Server 服务 。 
2. 以 @@ 作 为 首部 的 变量 在 SQL Server 系统 中 称 为 
3. SELECT 语句 的 完整 语法 较 复杂 ,但 至 少 包括 的 部 分 有 。 使 用 
关键 字 可 以 把 重复 行 屏蔽 ,将 多 个 查询 结果 返回 一 个 结果 集合 的 运算 符 
是 。 
4. 声明 游标 的 命令 是 ,释放 游标 的 命令 是 
5. 在 SQL Server 系统 中 ,用 户 要 访问 默认 工作 数据 库 中 的 数据 ,必须 在 s 
之 后 才能 进行 。 
6. 使 用 系统 监视 器 可 以 通过 创建 和 报表 ,以 监视 SQL 
Server 实例 的 运行 情况 。 


三 、 简 答题 (每 题 5 分 , 共 20 分 ) 

1. 如 果 给 某 用 户 授予 更 新 表 的 权限 ,但 该 用 户 所 属 角色 又 拒绝 了 此 权限 ,那么 该 用 户 
账户 是 否 保留 更 新 表 的 权限 ? 阐述 原因 。 

2. 简 述 public 角色 的 功能 。 

3. 用 户 数据 库 包括 由 气象 卫星 收集 的 图 像 数 据 , 并 且 这 些 数据 不 断 地 进行 更 新 。 数 据 
库 大 小 为 700GB, 被 划分 到 5 个 文件 中 保存 。 如 果 准 备 对 其 进行 完全 数据 库 备 份 ,那么 将 耗 
时 20 个 小 时 。 请 问 : 如 何 才能 尽量 缩短 每 天 执行 备份 所 需 的 时 间 ,并 且 在 系统 出 现 故障 的 
情况 下 仍然 能 够 保证 较 好 的 数据 还 原 能 力 呢 ? 

4. 说 明 如 何 创建 一 个 名 为 MyDevice 的 备份 设备 的 步 又? 如 何 将 其 映射 成 为 磁盘 文件 
“D:\DATA\MyDevice. BAK”。 

四 、 综 合 题 (每 题 5 分 . 共 50 分 ) 

1. 利用 Transact-SQL 语句 完成 操作 。 

(1) 创建 一 个 名 称 为 store 的 数据 库 ,该 数据 库 包 含 一 个 数据 文件 和 一 个 日 志文 件 。 数 
据 文件 的 逻辑 文件 名 为 storeDB1_data, 磁 盘 文 件 名 为 storeDB1_data. mdf, 文 件 初始 容量 
为 5MB, 最 大 容量 为 17MB, 文 件 递增 容量 为 1MB( 数 据 库 创建 在 D:\SERVER 文件 夹 下 )， 
其 他 所 有 参数 均 取 默 认 值 。 

(2) 在 store 数据 库 中 创建 一 个 数据 表 orders, 表 结构 如 下 表 所 示 。 


orders 表 结 构 


列 名 数据 类 型 及 长 度 是 否 为 空 备 注 
订单 编号 nchar (10) no 主键 

客户 编号 nchar (10) no 

订购 日 期 datetime no 默认 值 为 系统 时 间 


(3) 向 表 orders 中 添加 一 个 “备注 ”字段 ,数据 类 型 为 nchar(40)。“ 备 注 ” 字 段 允 许 为 
NULL。 并 向 表 orders 中 添加 一 条 记录 。 

(4) 查看 orders 表 上 的 所 有 约束 。 

(5) 删除 订购 日 期 在 2018 年 7 月 7 日 以 前 的 记录 。 

(6) 在 store 数据 库 中 创建 新 表 expro, 并 将 其 number 字段 设置 为 主键 。 

(7) 创建 一 个 AFTER 触发 器 ,要 求实 现 以 下 功能 : 在 expro 表 上 创建 一 个 插入 、 更 新 
类 型 的 触发 器 TR_expro, 当 在 expro 字段 中 插入 或 修改 number 后 触发 该 触发 器 ,检查 
number 值 是 否 为 0 一 1000。 

2. 写 出 实现 下 列 操作 的 步骤 和 命令 。 

(1) 在 SQL Server Management Studio 中 添加 登录 名 CLASS ,密码 为 BESTtoYOU 的 
SQL 登录 账户 ,并 映射 为 数据 库 TEACHING 的 数据 库 用 户 HANS。 

(2) 配置 对 数据 库 TEACHING 具有 创建 表 和 创建 视图 的 权限 。 

(3) 授予 对 数据 表 student 进行 查询 、 删除 的 权限 ,撤销 对 数据 表 course 的 择 入、 更 新 、 


删除 权限 。 


SQL Server 数据 库 柑 拟 试题 5 


SQL Server 数据 库 模拟 试题 5 参考 答案 


一 、 选 择 题 (每 题 1 分 , 共 15 分 ) 

1~5. CCBAC 6~10. BBACA 11~15. CCCAB 

二 、 填空 题 (每 空 1 分, 共 14 分 ) 

1. 启动 .暂停 ” 2. 全 局 变量 3. SELECT 、 FROM .DISTINCT.UNION 

4. DECLARE..CURSOR `.DEALLOCATE 

5. 登录 服务 器 、 进 行 身份 验证 、 获 得 权限 6. 图 表 、 警 报 、 日 志 

三 、 简 答题 (每 题 5 分 , 共 20 分) 

1. 该 用 户 不 再 保留 更 新 表 的 权限 。 因 为 拒绝 权限 优先 级 高 于 其 他 权限 ,从 而 将 使 授予 
给 他 的 权限 失效 。 

2. public 角色 是 一 个 特殊 的 数据 库 角色 ,SQL Serve 中 的 每 个 数据 库 都 拥有 该 角色 。 
其 主要 功能 包括 捕获 数据 库 用 户 的 所 有 默认 权限 ,包含 的 所 有 系统 数据 库 和 用 户 数据 库 中 ， 
并 且 无 法 删除 。 

3. 用 户 可 以 选用 一 种 以 完全 数据 库 备 份 开始 的 备份 计划 。 由 于 完全 数据 库 备 份 比较 
费时 ,所 以 极 少 进行 这 种 备份 ,而 是 以 轮流 方式 每 天 只 备份 数据 库 文件 中 的 一 个 。 为 了 尽量 
缩短 还 原 时 间 ,除了 备份 事务 日 志 以 外 ,用 户 还 应 当 执行 差异 备份 。 

4. 实现 创建 备份 设备 MyDevice, 以 及 将 其 映射 成 为 磁盘 文件 D:\DATA\MyDevice. 
BAK 的 步 又 如 下 : 

(1) 在 SQL Server Management Studio 中 展开 服务 器 组 ,展开 指定 的 服务 器 ,展开 “ 服 
务 器 对 象 ”。 

(2) 右 击 服务 器 对 象 中 的 “备份 设备 ”, 在 弹出 的 快捷 菜单 中 选择 “新 建 备份 设备 ”命令 ， 
打开 “备份 设备 ”对 话 框 。 

(3) 在 “设备 名 称 ” 文 本 框 中 输入 MyDevice, 并 单 击 “ 文 件 ”" 右 部 的 “…” 按 钮 ,打开 “定位 
数据 库 文件 ”对 话 框 ,在 对 话 框 中 选择 D 盘 的 DATA 文件 夹 ,并 在 窗口 下 部 的 “文件 名 ” 文 
本 框 中 输入 MyDevice. BAK , 单 击 “确定 ?按钮 。 

(4) 在 “备份 设备 ”对 话 框 中 单 击 “ 确 定 ” 按 钮 ,就 创建 了 备份 设备 MyDevice, 在 SQL 
Server Management Studio 中 可 看 到 此 备份 设备 名 称 。 

四 、 综 合 题 ( 每 题 5 分 . 共 50 分 ) 


1. (1) Create database store 
ON( 
NAME = storeDB1 data, 
FILENAME = 'D:\server\storeDB1 data. mdf', 
SIZE = 5mb, 
MAXSIZE = 17mb, 
FILEGROWTH = 1mb 


(2) create table orders 
(订单 编号 nchar(10) primary key, 
客户 编号 nchar(10)， 
订购 日 期 datetime default getdate() 
) 


(3) alter table orders add 备注 nchar(40) 
INSERT INTO orders 
VALUES( 'DO010552037', 'K021772097', getdate( ), NULL) 


(4) sp_helpconstraint orders 
(5) delete from orders where 订购 日 期 <'07/7/2018" 


(6) USE store 
GO 
CREATE TABLE expro 
( number int PRIMARY KEY, 
name nchar(20), 


(7) USE store 
GO 
CREATE TRIGGER TR_expro 
ON expro 
FOR INSERT, UPDATE 
RS 
IF UPDATE( number) 
PRINT 'AFTER 触发 器 开始 执行 …… 
BEGIN 
DECLARE @number Value real 
SELECT @numberValue = (SELECT number 
FROM inserted) 
IF @numberValue > 1000 OR @numberValue <0 
PRINT ' 输 入 的 编号 有 误 ,请 确认 输入 的 编号 !， 
END 
GO 


2. (1) 一 添加 CLASS 登录 账户 : 
sp_addlogin 'CLASS', ' BESTtoYOU ' 
一 映射 CLASS 为 TEACHING 数据 库 用 户 
sp_grantdbaccess 'CLASS', 'HANS' 
(2) 一 授予 创建 数据 表 、 创 建 视图 的 权限 
grant create table, create view to HANS 
(3) 一 授予 对 数据 表 student 进行 查询 .删除 权限 
grant select, delete on student to HANS 
一 视图 对 数据 表 course 的 插入 、 更 新 和 删除 权限 


revoke insert, update, delete on course to HANS 


SQL Server 数据 亩 模拟 试题 5 参考 答案 


ls 


a 


8. 
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说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 , 总 计 100 分 。 


、 选 择 题 (每 题 1 分 , 共 20 分 ) 


下 列 语句 用 于 创建 视图 。 
A. CREATE TRIGGER B. CREATE PROC 
C. CREATE VIEW D. 其 他 
.SQL Server 2016 中 提供 的 单行 注释 语句 是 使 用 开始 的 一 行内 容 。 
是 法 加 B.“--” 让 Dh 
. 在 SQL Server 中 定义 临时 表 时 , 表 名 前 面 的 字符 为 
A. * B. # C. @@ D. @ 
.对 视图 的 描述 错误 的 是 a 


A. 视图 是 一 张 虚拟 的 表 

B. 在 存储 视图 时 存储 的 是 视图 的 定义 
C. 在 存储 视图 时 存储 的 是 视图 中 的 数据 
D. 可 以 像 查询 表 一 样 来 查询 视图 


. 在 Transact-SQL 语言 中 , 若 要 修改 表 的 结构 ,应 该 使 用 的 修改 关键 字 是 
A. ALTER B. UPDATE C. UPDAET D. ALLTER 
.要 查询 book 表 中 所 有 书 名 中 以 “计算 机 ”开头 的 书籍 的 价格 ,可 用 语句 。 


A. SELECT price FROM book WHERE book_name 二 "计算机 x*， 
B. SELECT price FROM book WHERE book_name LIKE ' 计 算 机 x*，' 
C. SELECT price FROM book WHERE book_name 一 ' 计 算 机 %' 
D. SELECT price FROM book WHERE book_name LIKE ' 计 算 机 %' 


.下列 数据 库 是 SQL Server 在 创建 数据 库 时 使 用 的 模板 。 


A. master B. north C. model D. msdb 


用 户 希 望 从 master 数据 库 中 访问 north 数据 库 中 的 order 表 , 则 查询 语句 中 对 象 的 


引用 为 


9. 


10. 


kk 


A. north. order B. order C. north..order D. master..order 
以 下 关于 数据 存储 的 描述 错误 的 是 。 

A. 所 有 数据 库 都 有 一 个 主要 数据 库 文件 (. mdf) 

B. 创建 数据 库 时 会 利用 model 数据 库 复 制 新 的 数据 库 

C. 同一 行 的 数据 只 能 够 存储 在 不 同 的 页 上 

D. 一 个 数据 库 中 每 1 兆 字 节 的 空间 能 存储 128 个 页 


下 列 语言 中 属于 结构 化 查询 语言 的 是 。 
A. Java B. SQL C. C# D. C++ 
使 用 SELECT 语句 显示 表 的 所 有 列 时 ,选用 的 符号 是 。 


A. * B. [] CGC. Bb... 


12. 


13. 


14. 


16. 


Li 


18. 
为 


使 用 SELECT 语句 检索 带 特 定 条 件 的 数据 时 ,应 使 用 的 关键 字 是 a 
A. ORDER B. BETWEEN C LIKE D. WHERE 
需要 面试 分 数 (siTestScore) 在 70 一 90 的 候选 人 ,合适 的 查询 语句 是 
A. SELECT vFirstName,vLastName,siTestScore 

FROM ExternalCandidate 

WHERE siTestScore >70 OR siTestScore 一 90 
B. SELECT vFirstName,vLastName,siTestScore 

FROM ExternalCandidate 

WHERE siTestScore>70 AND siTestScore=90 
C. SELECT vFirstName,vLastName,siTestScore 

FROM ExternalCandidate 

WHERE siTestScore=70 AND siTestScore>90 
D. SELECT vFirstName,vLastName,siTestScore 

FROM ExternalCandidate 

WHERE siTestScore=70 OR siTestScore>90 
PRINT DATENAME(dw,'2018-1-1') 执 行 的 结果 。 
A = B1 C. 星期 一 D. 6 


. 下 列 角色 或 者 用 户 拥有 SQL Server 服务 器 范围 内 的 最 高 权限 。 


A. dbo B. sysadmin C. public D. guest 

游标 就 是 指向 内 存 中 结果 集 的 

A. 协议 B. 操作 C. 指针 D. 行 集 

用 来 对 两 个 字符 串 进行 比较 的 函数 是 o 

A. TRIM B. DIFFERENCE C. STUFF D. REVERSE 
有 如 下 Transact-SQL 语句 , 若 输出 为 “Helen: 88”, 则 SQL 输出 语句 应 


DECLARE @name char(20),@score float 
SELECT @name = 'Helen', @score= 87.5 


19. 


A. PRINT RTRIM(@name) +CONVERT(varchar, @ score) 
B. PRINT @name+CONVERT(varchar, @score) 

PRINT LTRIM(@name) +CONVERT(varchar., @ score) 

. PRINT RTRIM(@name) + @score ) 

下 列 连接 保证 包含 第 一 个 表 中 的 所 有 行 和 第 二 个 表 中 的 所 有 匹配 行 。 
A. LEFT OUTER JOIN B. RIGHT OUTER JOIN 

C. CROSS JOIN D. INNER JOIN 


gn 


20. 陈述 A: SQL Server 的 每 个 表 最 多 允许 有 1024 列 。 陈 述 B: 可 以 创建 表 的 同时 使 
用 用 户 自 定义 类 型 。 以 上 陈述 正确 的 是 


A. 都 是 错误 的 B. 都 正确 
C. 陈述 A 错误 ,陈述 B 正确 D. 陈述 A 正确 ,陈述 B 错误 
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SQL Server 2016 数据 府 应 用 与 开发 习题 解答 与 上 才 指 时 


二 、 填 空 题 ( 每 空 1 分 , 共 10 分 ) 


1. 服务 器 用 来 启动 、 和 停止 SQL Server 服务 。 
2. 以 @ 作 为 首部 的 变量 在 SQL Server 系统 中 称 为 
3. 网 络 数据 库 有 和 两 种 工作 模式 。 


4. 在 SQL Server 中 ,根据 索引 对 数据 表 中 记录 顺序 的 影响 ,索引 可 以 分 为 
和 

5. 外 键 约束 主要 用 来 实现 数据 的 和 完整 性 。 

6. 在 SQL Server 2016 中 可 以 利用 和 为 变量 赋值 。 

三 、 简 答题 (每 题 4 分. 共 20 分 ) 

1. 什么 是 死 锁 ? 如 何 处 理 ? 

2. 数据 库 备 份 的 方式 有 哪 几 种 ? 

3. 列 出 SQL Server 2016 数据 库 中 常见 的 数据 库 对 象 。 

4 

5 


. 简 述 存储 过 程 的 优点 。 

. 说 明 SQL Server 2016 中 聚集 索引 和 非 聚 集 索 引 的 区 别 。 

四 、 按 要 求 绘制 E-R 图 操作 ,并 设计 关系 (第 1 题 8 分 第 2.3 每 题 5 分 , 共 18 分 ) 

某 企 业 集团 有 若干 工厂 ,每 个 工厂 生产 多 种 产品 , 且 每 一 种 产品 可 以 在 多 个 工厂 生产 ， 
每 个 工厂 按照 固定 的 计划 数量 生产 产品 ; 每 个 工厂 聘用 多 名 职工 , 且 每 名 职工 只 能 在 一 个 
工厂 工作 ,工厂 聘用 职工 有 聘 期 和 工资 。 其 中 : 

工厂 的 属性 有 工厂 编号 、 厂 名 、 地 址 ; 

产品 的 属性 有 产品 号 .产品 名 ,规格 ; 

职工 的 属性 有 职工 号 、 姓 名 、 电 话 、 地 址 。 

1. 设计 满足 上 述 要 求 的 E-R 图 , 注 明 属性 (根据 自己 的 理解 ,用 下 划 线 标明 每 个 实体 中 
的 主 码 )。 

2. 将 E-R 图 转换 为 等 价 的 关系 模型 方式 。 

3. 指出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。 

五 、 根 据 下 列 数据 库 中 表 的 结构 , 写 出 SQL 语句 (每 题 4 分 , 共 32 分 ) 


student( 

学 号 char(8) primary key, 

姓名 char(8)， 

班级 char(10)， 

性 别 char(2)， 

出 生日 期 datetime, 

出 生 城 市 char(20)， 

入 学 成 绩 tinyint) 

course( 

课程 号 char(6) primary key, 

课程 名 char(20)) 

c_select( 

学 期 char(2)， 

学 号 char(8) references student( 学 号 )， 
课程 号 char(6) references course( 课 程 号 )， 
成 绩 tinyint check( 成 绩 > = 0 and 成 绩 <= 100) 


oo 站 叮嘱 


. 查询 缺少 成 绩 的 student 的 学 号 和 相应 的 课程 号 。 

. 查询 1803 物流 班 全 体 学 生 的 学 号 与 姓名 , 且 按 照 人 学 成 绩 降 序 排列 。 

. 统计 平均 人 学 总 分 在 650 分 以 上 的 班级 和 这 些 班 级 的 平均 人 学 总 分 。 

. 查询 选修 了 “实用 英语 ”课程 的 学 生 的 学 号 ,以 及 “实用 英语 ”课程 的 成 绩 。 


查询 第 二 学 期 所 选课 程 平均 成 绩 在 前 3 名 的 学 生 的 学 号 和 姓名 。 


. 在 student 表 上 增加 一 个 image 列 存放 照片 。 
. 修改 student 表 上 的 "出 生日 期 ? 列 ,使 其 类 型 为 date。 
. 将 course 表 的 select 和 update 权限 授予 数据 库 用 户 user2 。 
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SQL Server 数据 库 模拟 试题 6 参考 答案 


一 、 选 择 题 ( 每 题 1 分 , 共 20 分) 

1~5. CBBCA 6 一 10. DCCCB 11~15. ADBCB 16~20. CBAAB 

二 、 填空 题 (每 空 1 分 , 共 10 分) 

1. 暂停 ” 2. 局 部 变量 3. C/S 模 式 .B/S 模式 

4. 聚集 索引 、 非 聚集 索引 5. 区 域 .参照 6. set,select 

三 、 简 答题 (每 题 4 分 , 共 20 分 ) 

1. 死 锁 是 一 种 条 件 , 当 两 个 用 户 或 会 话 具 有 不 同 对 象 的 锁 , 且 每 个 用 户 需 要 另 一 个 用 
户 的 锁 时 就 会 发 生死 锁 现 象 。 一 般 情况 下 ,其 中 一 个 用 户 连 接 被 选 做 放弃 操作 。 

2. 数据 库 备 份 的 方式 有 完全 数据 库 备 份 .差异 备份 .事务 日 志 备 份 \. 对 指定 文件 或 文件 
组 备份 。 

3. SQL Server 2016 数据 库 中 常见 的 数据 库 对 象 有 表 、 存 储 过 程 、 触 发 器 、 视 图 、 规 则 、 
默认 值 . 索 引 等 。 

4. 存储 过 程 是 SQL 语句 和 流程 控制 语句 的 集合 。 存 储 过 程 使 程序 执行 效率 更 高 , 安 
全 性 更 好 ,因为 过 程 建 立 之 后 已 经 编译 并 且 储存 到 数据 库 ,直接 写 SQL 语句 先 分 析 青 执行 ， 
因此 过 程 效率 更 高 ,直接 写 SQL 语句 安全 性 更 好 。 建 立 过 程 不 会 消耗 很 多 系统 资源 ,因为 
过 程 只 是 在 调用 时 才 执 行 。 存 储 过 程 包括 系统 存储 过 程 和 用 户 定义 的 存储 过 程 两 种 。 

5. 聚集 索引 确定 表 中 数据 的 物理 顺序 。 由 于 聚集 索引 规定 数据 在 表 中 的 物理 存储 顺 
序 , 因 此 一 个 表 只 能 包含 一 个 聚集 索引 。 但 该 索引 可 以 包含 多 个 列 (组 合 索引 ) 。 

非 聚集 索引 也 是 一 种 索引 ,该 索引 中 索引 的 逻辑 顺序 与 磁盘 上 行 的 物理 存储 顺序 不 同 。 
一 个 表 可 以 有 多 个 聚集 索引 。 

四 、 按 要 求 绘制 E-R 图 操作 ,并 设计 关系 (第 1 题 8 分 ,第 2 和 第 3 题 每 题 5 分 , 共 18 分) 

1. 绘制 E-R 图 如 下 。 


产品 号 产品 规格 
m 

D> 
| 

2 I 1 聘用 地 址 
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图 1 企业 产品 ER 图 


2. 将 E-R 图 转换 为 等 价 的 关系 模型 方式 。 


工厂 (工厂 编号 , 厂 名 , 地址 ) 

产品 (产品 号 ,产品 名 ,规格 ) 

职工 (职工 号 ,姓名 ,地 址 ,电话 ,工厂 编号 , 聘 期 ,工资 ) 
生产 (工厂 编号 ,产品 编号 ,数量 ) 


3. 指出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。 


工厂 关系 主 码 : 工厂 编号 ,外 码 : 无 

产品 关系 主 码 : 产品 编号 , 外 码 : 无 

职工 关系 主 码 : 职工 号 ,外 码 : 工厂 编号 

生产 关系 主 码 : 工厂 编号 和 产品 编号 ,外 码 : 工厂 编号 和 产品 编号 


五 、 根 据 下 列 数据 库 中 表 的 结构 , 写 出 SQL 语句 (每 题 4 分, 共 32 分) 
1. select 学 号 ,课程 号 ”from c_select 
where 成 绩 is null; 
2. select 学 号 ,姓名 from student 
where 班级 = '1803 物流 ' 
order by 人 学 成 绩 desc; 
3. select 班级 ,avg( 人 学 成 绩 ) from student 
group by 班级 ; 
having avg( 人 学 成 绩 )> 650; 
4.。 select 学 号 ,成 绩 from c_select 
where 课程 号 = (select 课程 号 
from cousre 
where 课程 名 = ' 实 用 英语 ' 
) 
5。 select top 3 c_select. 学 号 , student .姓名 
from c_select, student 
wherec_select. 学 期 = “2’and c_select. 学 号 = student .学 号 
group byc_select. 学 号 
order by avg( 成 绩 ) 
6. alter table student add column image ; 
7. alter table student modify column 出 生日 期 date; 


8. grant select, update on course touser2@ 1ocalhost; 


SQL Server 数据 亩 模拟 试题 6 参考 答案 


图 书 资源 支持 


感谢 您 一 直 以 来 对 清华 版 图 书 的 支持 和 爱护 。 为 了 配合 本 书 的 使 用 ,本 书 
提供 配套 的 资源 ,有 需求 的 读者 请 扫描 下 方 的 “ 书 圈 " 微 信 公 众 
书 专区 下 载 ,也 可 以 拨打 电话 或 发 送 电子 邮件 咨询 。 

如 果 您 在 使 用 本 书 的 过 程 中 遇 到 了 什么 问题 ,或 者 有 相关 
也 请 您 发 邮件 告诉 我 们 ,以 便 我 们 更 好 地 为 您 服务 。 

我 们 的 联系 方式 : 

地 址 ; 北京 海淀 区 双 清 路 学 研 大 厦 A 座 707 

邮 ” 编 : 100084 

电 ” 话 : 010 一 62770175 一 4604 

资源 下 载 : http://www. tup. com.cn 

电子 邮件 : weijj@tup. tsinghua. edu. cn 


到 书 出 版 计划 ， 


资源 下 载 、 样 书 申请 


QQ: 883604( 请 写 明 您 的 单位 和 姓名 ) 


用 微 信 扫 一 扫 右 边 的 二 维 码 , 即 可 关注 清华 大 学 出 版 社 公众 号 “ 书 圈 "。 


